我在使用 Autofac 注册具体类时收到以下错误
这是课
[AutomaticRetry(Attempts = 0)]
public class NoRetryJob<T> where T : IRecurringJob
{
private T Job { get; set; }
private static readonly Logger logger = LogManager.GetCurrentClassLogger();
public NoRetryJob(T job)
{
Job = job;
Job.Error += LogError;
Job.Info += LogInfo;
}
}
这就是我使用 autofac 进行注册的方式
builder.RegisterGeneric(typeof(NoRetryJob<>)).InstancePerDependency();
builder.RegisterType<CachingService>().As<ICachingService>();
将上述类称为
JobRegistration.Add<NoRetryJob<PageCachingJob>>(nameof(PageCachingJob), j => j.Run(), Cron.Daily(1));
PageCachingJob 类 -
public class PageCachingJob : BaseJob, IRecurringJob
{
private readonly ICachingService _cachingService;
public DateTime? LastSuccessfulExecutionOn { get; set; }
public PageCachingJob(ICachingService cachingService) : base()
{
_cachingService = cachingService;
}
protected override void RunJob()
{
_cachingService.ClearRedisCache();
}
}
public class JobRegistration
{
public static void Add<T>(string jobName, Expression<Action<T>> methodCall, string cron)
{
RecurringJob.AddOrUpdate(jobName, methodCall, cron, TimeZoneInfo.Local);
}
}
BaseJob 类
public abstract class BaseJob
{
private static readonly Logger logger = LogManager.GetCurrentClassLogger();
public event EventHandler<string> Info;
public event EventHandler<string> Error;
protected BaseJob()
{
}
protected abstract void RunJob();
public virtual JobResponse Run()
{
var stopwatch = new Stopwatch();
var response = new JobResponse();
try
{
logger.Info($"Job {this.GetType().Name} - started.");
stopwatch.Start();
RunJob();
stopwatch.Stop();
logger.Info($"Job {this.GetType().Name} - successful.");
}
catch (Exception ex)
{
response.Success = false;
response.LogMessages.Add("Exception" + ex.Message);
response.LogMessages.Add("Stacktrace : " + ex.StackTrace);
logger.Error($"Job {this.GetType().Name} - failure." + ex);
LogError(response.LogMessages, $"Job {this.GetType().Name} - failure.", ex);
}
logger.Info($"Job {this.GetType().Name} - duration: {stopwatch.Elapsed:g}.");
return response;
}
private void LogError(IList<string> messages, string message, Exception ex)
{
messages.Add(DateTime.Now + ": ERROR " + message);
Error?.Invoke(this, message + " " + ex.Message);
}
}
界面 -
public interface IRecurringJob
{
event EventHandler<string> Info;
event EventHandler<string> Error;
DateTime? LastSuccessfulExecutionOn { get; set; }
JobResponse Run();
}
ICachingService 接口
public interface ICachingService
{
bool ClearRedisCache();
}
缓存服务类
public class CachingService : ICachingService
{
public CachingService()
{
}
public bool ClearRedisCache()
{
return true;
}
}
获取以下异常
在“PacDig.Atlantic.Schedule.Jobs.NoRetryJob`1[PacDig.Atlantic.Schedule.Jobs.PageCachingJob]”类型上使用“Autofac.Core.Activators.Reflection.DefaultConstructorFinder”找到的任何构造函数都不能使用可用服务调用和参数:无法解析构造函数“Void .ctor(PacDig.Atlantic.Schedule.Jobs.PageCachingJob)”的参数“PacDig.Atlantic.Schedule.Jobs.PageCachingJob 作业”。
提前致谢