Quartz.NET Windows 서비스의 스케줄러를 성공적으로로드했으며 현재 하나의 샘플 작업을 실행하고 있음을 알 수 있습니다. 하지만 내가 말하는 FileLoadException
예외 얻을 (라인 아래 sched.ScheduleJob(job, trigger)
에) 스케줄러에 작업을 추가하려고 :FileLoadException on ScheduleJob 메서드
파일이나 어셈블리 '석영를로드 할 수 없습니다를 버전 = 2.2.4.400을 문화 = neutral, PublicKeyToken = f6b8c98a402cc8a4 '또는 종속성 중 하나입니다. 위치한 어셈블리의 매니페스트 정의가 과 일치하지 않습니다. (HRESULT에서 예외 : 0x80131040)
이것은 내가 내 스케줄러를 얻고 그것에 작업과 트리거 추가 사용하고있는 코드입니다 :
NameValueCollection properties = new NameValueCollection();
properties["quartz.scheduler.instanceName"] = "RemoteClient";
// set thread pool info
properties["quartz.threadPool.type"] = "Quartz.Simpl.SimpleThreadPool, Quartz";
properties["quartz.threadPool.threadCount"] = "10";
properties["quartz.threadPool.threadPriority"] = "Normal";
// set remoting expoter
properties["quartz.scheduler.proxy"] = "true";
properties["quartz.scheduler.proxy.address"] = "tcp://127.0.0.1:555/QuartzScheduler";
ISchedulerFactory sf = new StdSchedulerFactory(properties);
IScheduler sched = sf.GetScheduler();
Console.WriteLine("name: " + sched.SchedulerName);
Console.WriteLine("instance id: " + sched.SchedulerInstanceId);
Console.WriteLine("is started: " + sched.IsStarted);
Console.WriteLine("context : " + sched.Context);
var job = JobBuilder.Create()
.WithIdentity("MyEmailJob", "JobCategory1")
.RequestRecovery().Build();
var trigger = (ICronTrigger)TriggerBuilder.Create()
.WithIdentity("MyEmailJob", "JobCategory1")
.WithCronSchedule("0 0/5 * 1/1 * ? *")
.StartAt(DateTime.Now) .WithPriority(1).Build();
var schedule = sched.ScheduleJob(job, trigger);
의 App.config :
가<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<configSections>
<section name="quartz" type="System.Configuration.NameValueSectionHandler, System, Version=1.0.5000.0,Culture=neutral, PublicKeyToken=b77a5c561934e089" />
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
<sectionGroup name="common">
<section name="logging" type="Common.Logging.ConfigurationSectionHandler, Common.Logging" />
</sectionGroup>
</configSections>
<common>
<logging>
<factoryAdapter type="Common.Logging.Log4Net.Log4NetLoggerFactoryAdapter, Common.Logging.Log4net1211">
<arg key="configType" value="INLINE" />
</factoryAdapter>
</logging>
</common>
<log4net>
<appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender">
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%d [%t] %-5p %l - %m%n" />
</layout>
</appender>
<appender name="FileAppender" type="log4net.Appender.FileAppender">
<file value="service-log.txt" />
<appendToFile value="true" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" />
</layout>
</appender>
<root>
<level value="INFO" />
<appender-ref ref="ConsoleAppender" />
<appender-ref ref="FileAppender" />
<!-- uncomment to enable event log appending -->
<!-- <appender-ref ref="EventLogAppender" /> -->
</root>
</log4net>
<!--
We use quartz.config for this server, you can always use configuration section if you want to.
Configuration section has precedence here.
-->
<!--
<quartz >
</quartz>
-->
</configuration>
내부 예외는 무엇이라고 말합니까? –
@CircularReference 내부 예외는 null을 반환하지만이 Fusionlog를 가져옵니다. WRN : 어셈블리 바인딩 로깅이 해제되어 있습니다. 어셈블리 바인드 실패 로깅을 사용하려면 [HKLM \ Software \ Microsoft \ Fusion! EnableLog] (DWORD) 레지스트리 값을 1로 설정하십시오. 참고 : 어셈블리 바인드 실패 로깅과 관련된 성능상의 불이익이 있습니다. 이 기능을 해제하려면 [HKLM \ Software \ Microsoft \ Fusion! EnableLog] 레지스트리 값을 제거하십시오. – Disasterkid
@CircularReference 시간 되감습니다. Quartz.NET 문제를 실제로 해결할 수있는 유일한 사람 인 것 같습니다. – Disasterkid