asp.net 挂起文件未找到异常:未能加载文件或程序集DynamicProxyGenAssembly,

pbwdgjma  于 2022-11-19  发布在  .NET
关注(0)|答案(3)|浏览(167)

我在设置后台作业后遇到了HangFire问题,但当我打开HangFire Jmeter 板时,我看到以下异常
System.IO.FileNotFoundException:未能加载文件或程序集“DynamicProxyGenAssembly2,Version=0.0.0.0,Culture=neutral,PublicKeyToken=null”或它的某个依赖项。系统找不到指定的文件。
正在使用AutoFac for DI注册所有接口。我正在startup.cs中设置以下内容
我在启动中有以下代码

GlobalConfiguration.Configuration.UseSqlServerStorage("Hangfire");
  app.UseHangfireDashboard();
  app.UseHangfireServer();

我有以下几点来学习这份工作

public class ScheduleAppService : IScheduleAppService
  {
    private readonly IRunCommandAppService _runCommandAppService;

    public ScheduleAppService(IRepository<Schedule> repository, IAdHocTemplateRunnerAppService adHocTemplateRunner) : base(repository)
    {
      _adHocTemplateRunner = adHocTemplateRunner;
    }

    public async Task CreateSchedule(ScheduleDto schedule)
    {
      input.Schedule.JobId = BackgroundJob.Schedule(
        () => _runCommandAppService.AddTemplate(
          new Template{ RunId = Guid.NewGuid().ToString(), TemplateId = schedule.Id }), schedule.Start);
    }
}

被调用的代码在这里

public class RunCommandAppService  : IRunCommandAppService 
  {
    private readonly IRepository<Template> _templateRepo;

    public RunCommandAppService (IRepository<Template> templateRepo)
    {
      _templateRepo = templateRepo;
    }

    public void AddTemplate(Template input)
    {
      try
      {
        Run(input);
      }
      finally
      {
        SetRunComplate(input.RunId);
      }
    }
jdzmm42g

jdzmm42g1#

可能与您的上下文不同,但我认为仍然值得在此添加:
-Hangfire服务器作为Windows服务运行;

  • 在ASP.NETMVC5应用程序上运行的Hangfire Jmeter 板;
  • 作业实际上正在运行,但 Jmeter 板一直显示FileNotFoundException;

**解决方案:**添加了对缺少的程序集的引用(即:“DynamicProxyGenAssembly2”)。

@reggieboyYEAH报告了相同的问题,并以相同的方式解决了该问题。
详细信息:https://github.com/HangfireIO/Hangfire/issues/558

busg9geu

busg9geu2#

我也有同样的问题。但是我试着把包含BackgroundJob.Enqueue的方法移到一个vm类中。当我想调用这个方法的时候,我会新建一个vm类。然后用vm来调用这个方法。它会成功的。我想原因是一些资源被两个对象同时使用。不管怎样,它可以运行。我希望这能帮助你。
我的例外如下:

warn: Hangfire.AutomaticRetryAttribute[0]
  Failed to process the job '15': an exception occurred. Retry attempt 3 of 10 will be performed in 00:01:01.
`System.IO.FileNotFoundException: 未能加载文件或程序集“DynamicProxyGenAssembly2,     Version=0.0.0.0, Culture=neutral, PublicKeyToken=null”或它的某一个依赖项。系统找不到指定的文件。
文件名:“DynamicProxyGenAssembly2, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null”
   在 System.RuntimeTypeHandle.GetTypeByName(String name, Boolean throwOnError, Boolean ignoreCase, Boolean reflectionOnly, StackCrawlMarkHandle stackMark, IntPtr pPrivHostBinder, Boolean loadTypeFromPartialName, ObjectHandleOnStack type)
   在 System.RuntimeTypeHandle.GetTypeByName(String name, Boolean throwOnError, Boolean ignoreCase, Boolean reflectionOnly, StackCrawlMark& stackMark, IntPtr pPrivHostBinder, Boolean loadTypeFromPartialName)
   在 System.Type.GetType(String typeName, Boolean throwOnError, Boolean ignoreCase)
   在 Hangfire.Storage.InvocationData.Deserialize()

=== 预绑定状态信息 ===
日志: DisplayName = DynamicProxyGenAssembly2, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null
 (Fully-specified)
日志: Appbase = file:///D:/Code/Test/bin/Debug/net461/
日志: 初始 PrivatePath = NULL
调用程序集: Hangfire.Core, Version=1.6.19.0, Culture=neutral, PublicKeyToken=null。`
===
日志: 此绑定从 default 加载上下文开始。
日志: 正在使用应用程序配置文件: D:\Code\Test\bin\Debug\net461\ Test.exe.Config
日志: 使用主机配置文件:
日志: 使用 C:\Windows\Microsoft.NET\Framework64\v4.0.30319\config\machine.config 的计算机配置文件。
日志: 此时没有为引用应用策略(私有、自定义、分部或基于位置的程序集绑定)。
日志: 相同的绑定已出现过,因 hr = 0x80070002 而失败。
3mpgtkmj

3mpgtkmj3#

input.Schedule.JobId = BackgroundJob.Schedule<IAdHocTemplateRunnerAppService >(
            x =>
                x.AddTemplate (new Template{ RunId = Guid.NewGuid().ToString(), TemplateId = schedule.Id }), input.Schedule.Start);

相关问题