首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >FileLoadException on ScheduleJob方法

FileLoadException on ScheduleJob方法
EN

Stack Overflow用户
提问于 2014-10-21 09:55:18
回答 1查看 849关注 0票数 0

我已经成功地加载了我的Quartz.NET windows服务的调度程序,并且我可以看到它目前正在运行一个示例作业。但是,当我试图将作业添加到调度程序(在下面的行sched.ScheduleJob(job, trigger)中)时,我得到一个FileLoadException异常,它说:

无法加载文件或程序集“Quartz、Version=2.2.4.400、Culture=neutral、PublicKeyToken=f6b8c98a402cc8a4”或其依赖项之一。所定位的程序集的清单定义与程序集引用不匹配。(HRESULT例外: 0x80131040)

这是我用来获取调度程序并将作业和触发器添加到其中的代码:

代码语言:javascript
复制
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:

代码语言:javascript
复制
<?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>
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-10-21 11:04:25

这是一个程序集不匹配的问题,而不是任何与quartz.net有关的问题。这意味着您的应用程序无法在运行时找到Quartz.dll的确切版本。bin文件夹中的版本与项目引用的版本不同。

尝试从项目中删除引用并重新添加它。选择windows服务使用的那个。干净的溶液,重建。

如果您使用nuget安装Quartz,您需要首先通过nuget卸载它。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/26483845

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档