令人恐惧的“在扫描的程序集中找不到端点配置” NServiceBus错误

问题描述

|| 背景: 我的解决方案中有两个NServiceBus终结点项目。 两者都是NServiceBus订户,并且包含一条消息的消息处理程序。 每个订户项目都处理来自两个不同发布者之一的消息。这样,一个项目引用了一个发布者的消息DLL,另一个项目引用了另一发布者的消息DLL。 两家出版商都在我的解决方案外部。 除了消息DLL,两个订户项目都为NServiceBus引用相同的二进制文件,并且具有完全相同的设置(UnicastBusConfig,EndpointConfig,appSettings等)。 一个订阅者项目运行正常,但另一个订阅者项目失败并出现以下错误: 未处理的异常:System.InvalidOperationException:在扫描的程序集中找不到端点配置。当NServiceBus无法加载包含IConfigureThisEndpoint的程序集时,通常会发生这种情况。尝试使用appsetting键在NServiceBus.Host.exe.config中显式指定类型:EndpointConfigurationTypeScanned路径:我的路径    在NServiceBus.Host.Program.ValidateEndpoints(IEnumerable`1 endpointConfigurationTypes)    在NServiceBus.Host.Program.GetEndpointConfigurationType()    在NServiceBus.Host.Program.Main(String [] args) 我的怀疑是问题必须在于无法启动的订户的NServiceBus发布者消息DLL。但是,我不确定如何解决此问题。我看了看: NServiceBus发布者消息DLL的清单都使用ildasm,并且它们是相同的(关于处理器标志和所引用的NServiceBus DLL版本)。 NSB邮件项目,这两个项目都是使用.Net 3.5 Framework构建的。 我在这里疯了,已经花了将近一天的时间试图使它正常工作。任何帮助将不胜感激。     

解决方法

好吧,异常会告诉您确切的含义。 它正在寻找实现IConfigureThisEndpoint的类。 我想到三件事: 您忘记了实现(请看一下NServiceBus示例) 您实现了它,但是您的课程不是公开的或内部的 您的文件所在的文件夹或子文件夹中有多个实现IConfigureThisEndpoint的程序集 程序集的框架版本与NServiceBus程序集之间存在不匹配,即您正在使用为.NET 3.5编译的NServiceBus,但Visual Studio 2010创建了终结点(默认情况下)为.NET 4.0。 (David Boike添加的观点) 失败的订户正在引用的消息DLL是延迟签名的。这导致它失败,并显示“找不到端点配置...”错误。在本地构建消息DLL的强命名版本可以解决此问题。 (点由颜色添加) 出现“没有端点配置...”异常的原因很多,它掩盖了实际原因。异常基本上仅表示无法找到配置,没有指定问题的原始原因。 (点由颜色添加) 我们使用的NServiceBus版本未针对.NET v4进行编译。因此,我们需要创建一个配置文件NServiceBus.Host.exe.config,以配置要使用的.NET版本。 不要忘记设置要复制的NServiceBus.Host.exe.config文件到属性窗口中的/ bin / Debug文件夹中。一直在我身上... ;-) NServiceBus.Host.exe.config文件应如下所示:
<?xml version=\"1.0\" encoding=\"utf-8\"?>
<configuration>
   <startup>
      <supportedRuntime version=\"v4.0\" />
   </startup>
   <runtime>
       <loadFromRemoteSources enabled=\"true\" />
    </runtime>
</configuration>
我认为似乎由于多种原因引发了“没有端点配置...”异常,并且它掩盖了实际原因。有谁知道诊断此类问题的好方法? 最后一点也发生在我身上。重命名我的程序集并没有清除项目目录后发生了这种情况。 NServiceBus然后遍历所有文件,找到旧的命名程序集和新的命名程序集,并以相同的异常结束。 请注意,如果包含相同接口实现的第二个程序集位于子文件夹中,则可能会导致此错误,也会发生这种情况。这种行为使我有些调试头痛,因为我以前曾将文件复制到子文件夹中作为短期备份... [编辑] 编辑是为了使其他作者在此主题中添加其他项,以确保完整性。 [编辑2] 添加了有关
NServiceBus.Host.exe.config
的更多信息。     ,在我的情况下,我遇到了此异常,因为我使用了NServiceBus安装路径中的NServiceBus.Host.exe。将其更改为bin / debug副本(在两种情况下:服务器和客户端)后,程序启动正确。 项目属性->调试->启动外部程序-> bin / debug文件夹中NServiceBus.Host.exe的完整路径     ,好吧,真正的面部表情时刻-失败的订户正在引用的消息DLL仅经过延迟签名。这导致它失败,并显示“找不到端点配置...”错误。一旦在本地构建了消息DLL的强命名版本,它就解决了该问题。 我认为似乎由于多种原因引发了“没有端点配置...”异常,并且它掩盖了实际原因。有谁知道诊断此类问题的好方法?     ,当项目的构建属性设置为在x86的平台目标上运行时,我也看到了类似的内容。 我最初将项目设置为控制台应用程序的输出类型,这导致该项目使用平台目标x86创建。 后来我将项目类型更改为类库(但未能将平台类型更改为\“ Any CPU \”)。 将平台目标更改为任何CPU使其开始工作。     ,找到了可能导致此异常的其他情况,该情况当前未包含在接受的答案中。它特定于使用Azure作为NServiceBus传输/持久性机制。 当未正确安装Azure SDK时,也会为我们发生此错误。 (这是怎么发生的?如果您要获取最新版本的SDK,则平台安装程序会很好用,但是单独安装SDK组件可能会导致缺少组件。) 详细介绍:Fusion Log指示NServiceBus.Host.exe无法解析Microsoft.WindowsAzure.ServiceRuntime。 解决方案是安装以下所有组件(甚至需要使用仿真器才能解决所有依赖项): WindowsAzureStorageTools.msi WindowsAzureEmulator-x64.exe WindowsAzureTools.vs120.exe WindowsAzureAuthoringTools-x64.msi WindowsAzureLibsForNet-x64.msi 在我们的特殊情况下,我们必须从以下网站获取sdk的2.3版本:http://www.microsoft.com/zh-CN/download/details.aspx?id=42317 希望此信息对某人有所帮助。     

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...