Сервис 'Abp.Quartz.IQuartzScheduleJobManager', который не был зарегистрирован - PullRequest
0 голосов
/ 08 июня 2018

Я скачал шаблон .NET Core + Vue для ASP.NET Boilerplate (v3.7.0).

Я добавил:

[DependsOn(typeof(AbpAutoMapperModule), typeof(AbpQuartzModule))]
public class MyAbpQuartzModule : AbpModule
{
  public override void Initialize()
  {
    IocManager.RegisterAssemblyByConvention(Assembly.GetExecutingAssembly());
  }
}
  • MyAbpQuartzController.cs в xxx.Web.Host проект:
public class MyAbpQuartzController : AbpController
{
  private readonly IQuartzScheduleJobManager _jobManager;

  public MyAbpQuartzController(IQuartzScheduleJobManager jobManager)
  {
      _jobManager = jobManager;
  }

  public async Task<ActionResult> ScheduleJobWithTask()
  {
      await _jobManager.ScheduleAsync<MyLogJob>(
          job =>
          {
              job.WithIdentity("MyLogJobIdentity", "MyGroup")
                  .WithDescription("A job to simply write logs.");
          },
          trigger =>
          {
              trigger.StartNow()
                  .WithSimpleSchedule(schedule =>
                  {
                      schedule.RepeatForever()
                          .WithIntervalInSeconds(5)
                          .Build();
                  });
          });

      return Content("OK, scheduled!");
  }

  public ContentResult TestMyAbpQuartz(string message = "")
  {
      return Content("OK, scheduled!");
  }
}

Я отладил проект xxx.Web.Host , но он не работал.

Страница http://localhost:21021/MyAbpQuartz/TestMyAbpQuartz вернулась:
"Эта страница не работает. Localhost в настоящее время не может обработать этот запрос. HTTP ERROR 500"

Я думаю, что QuartzScheduleJobManager не удалось успешно зарегистрироваться.

Итак, что мне делать?

Часть сообщения об ошибке в Web.Host / App_Data / log.txt :

ERROR 2018-06-08 19:19:04,161 [5    ] Mvc.ExceptionHandling.AbpExceptionFilter - Can't create component 'MyNetCoreWithVueProject.Web.Host.Controllers.MyAbpQuartzController' as it has dependencies to be satisfied.

'MyNetCoreWithVueProject.Web.Host.Controllers.MyAbpQuartzController' is waiting for the following dependencies:
- Service 'Abp.Quartz.IQuartzScheduleJobManager' which was not registered.

Castle.MicroKernel.Handlers.HandlerException: Can't create component 'MyNetCoreWithVueProject.Web.Host.Controllers.MyAbpQuartzController' as it has dependencies to be satisfied.

'MyNetCoreWithVueProject.Web.Host.Controllers.MyAbpQuartzController' is waiting for the following dependencies:
- Service 'Abp.Quartz.IQuartzScheduleJobManager' which was not registered.

   at Castle.MicroKernel.Handlers.DefaultHandler.AssertNotWaitingForDependency()
   at Castle.MicroKernel.Handlers.DefaultHandler.ResolveCore(CreationContext context, Boolean requiresDecommission, Boolean instanceRequired, Burden& burden)
   at Castle.MicroKernel.Handlers.DefaultHandler.Resolve(CreationContext context, Boolean instanceRequired)
   at Castle.MicroKernel.DefaultKernel.ResolveComponent(IHandler handler, Type service, IDictionary additionalArguments, IReleasePolicy policy)
   at Castle.MicroKernel.DefaultKernel.Castle.MicroKernel.IKernelInternal.Resolve(Type service, IDictionary arguments, IReleasePolicy policy)
   at Castle.Windsor.MsDependencyInjection.ScopedWindsorServiceProvider.GetServiceInternal(Type serviceType, Boolean isOptional) in D:\Github\castle-windsor-ms-adapter\src\Castle.Windsor.MsDependencyInjection\ScopedWindsorServiceProvider.cs:line 55
   at Microsoft.AspNetCore.Mvc.Controllers.ControllerFactoryProvider.<>c__DisplayClass5_0.<CreateControllerFactory>g__CreateController|0(ControllerContext controllerContext)
   at Microsoft.AspNetCore.Mvc.Internal.ControllerActionInvoker.Next(State& next, Scope& scope, Object& state, Boolean& isCompleted)
   at Microsoft.AspNetCore.Mvc.Internal.ControllerActionInvoker.<InvokeInnerFilterAsync>d__14.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.ExceptionServices.ExceptionDispatchInfo.Throw()
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at Microsoft.AspNetCore.Mvc.Internal.ResourceInvoker.<InvokeNextExceptionFilterAsync>d__23.MoveNext()
INFO  2018-06-08 19:19:04,967 [5    ] ore.Mvc.Internal.ControllerActionInvoker - Executed action MyNetCoreWithVueProject.Web.Host.Controllers.MyAbpQuartzController.TestMyAbpQuartz (MyNetCoreWithVueProject.Web.Host) in 833.6801ms
ERROR 2018-06-08 19:19:05,059 [5    ] Microsoft.AspNetCore.Server.Kestrel      - Connection id "0HLED66DNH26L", Request id "0HLED66DNH26L:00000004": An unhandled exception was thrown by the application.
Castle.MicroKernel.Handlers.HandlerException: Can't create component 'MyNetCoreWithVueProject.Web.Host.Controllers.MyAbpQuartzController' as it has dependencies to be satisfied.

Ответы [ 2 ]

0 голосов
/ 09 июня 2018

IQuartzScheduleJobManager должно быть зарегистрировано AbpQuartzModule.

Я вижу, что у вас уже есть [DependsOn(typeof(AbpQuartzModule))] на MyAbpQuartzModule.

Добавить [DependsOn(typeof(MyAbpQuartzModule))] к *WebHostModule:

[DependsOn(
    typeof(AbpProjectNameWebCoreModule),
    typeof(MyAbpQuartzModule))]
public class AbpProjectNameWebHostModule : AbpModule
0 голосов
/ 08 июня 2018

Если вы хотите зарегистрировать определенный класс, который не вписывается в обычные правила регистрации.ASP.NET Boilerplate предоставляет интерфейсы ITransientDependency, IPerWebRequestDependency и ISingletonDependency в виде ярлыка.

public interface IQuartzScheduleJobManager
{
    //...
}

public class QuartzScheduleJobManager: IQuartzScheduleJobManager, ITransientDependency
{
    //...
}
...