2014-10-21 1 views
0

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> 
+1

내부 예외는 무엇이라고 말합니까? –

+0

@CircularReference 내부 예외는 null을 반환하지만이 Fusionlog를 가져옵니다. WRN : 어셈블리 바인딩 로깅이 해제되어 있습니다. 어셈블리 바인드 실패 로깅을 사용하려면 [HKLM \ Software \ Microsoft \ Fusion! EnableLog] (DWORD) 레지스트리 값을 1로 설정하십시오. 참고 : 어셈블리 바인드 실패 로깅과 관련된 성능상의 불이익이 있습니다. 이 기능을 해제하려면 [HKLM \ Software \ Microsoft \ Fusion! EnableLog] 레지스트리 값을 제거하십시오. – Disasterkid

+0

@CircularReference 시간 되감습니다. Quartz.NET 문제를 실제로 해결할 수있는 유일한 사람 인 것 같습니다. – Disasterkid

답변

1

이것은 quartz.net과 관련이없는 어셈블리 불일치 문제입니다. 즉, 앱이 런타임시 정확한 버전의 Quartz.dll을 찾을 수 없다는 뜻입니다. bin 폴더의 버전이 프로젝트에서 참조한 버전과 다릅니다.

프로젝트에서 참조를 제거하고 다시 추가해보십시오. 귀하의 Windows 서비스가 사용하는 하나를 선택하십시오. 깨끗한 솔루션, 재건.

너겟을 사용하여 쿼츠를 설치 한 경우 먼저 너겟을 통해 제거해야합니다.

+0

Genius! 고맙습니다. Lesson은 내 서버가 사용하고있는 DLL을 항상 사용해야한다는 것을 알게되었습니다. – Disasterkid

관련 문제