【问题标题】:StructureMap Exception: "Entry point was not found" in NServiceBus project for EPiServer integrationStructureMap 异常:在 EPiServer 集成的 NServiceBus 项目中“找不到入口点”
【发布时间】:2014-01-09 12:38:22
【问题描述】:

我正在尝试初始化一个调用 EPiServer.Framework (v7.0.859.1) 和其他 Mediachase (v7.0.243) 库的 NServiceBus (v4.3.2) 端点来初始化对数据库的访问。我的班级ServerEndpoint 实现了NServiceBus.IWantToRunWhenTheBusStopsAndStarts。它的构造函数依赖于StructureMap.IContainer,以便让容器在初始化例程Start() 中使用。我已将依赖项添加到项目中以使用带有 NServiceBus 的 StructureMap 2.6.4。

但是,当我启动端点时,我不断收到 System.EntryPointNotFoundException 异常消息“未找到入口点”:

2014-01-07 23:16:30,581 [14] ERROR NServiceBus.Unicast.UnicastBus [(null)] <(null)> - System.EntryPointNotFoundException: Entry point was not found.
   at StructureMap.IContainer.Configure(Action`1 configure)
   at Mediachase.Commerce.Initialization.CommerceInitialization.ConfigureContainer(ServiceConfigurationContext context)
   at clin.Integration.Commerce.Initialization.InitCommerceServices(IContainer container1) in c:\dev\clin\kimball\Trunk\NServiceBus\clin.ServiceBus\clin.Integration.Commerce\Initialization.cs:line 18
   at clin.Web.CatalogChangeEndpoint.ServerEndpoint.Start() in c:\dev\clin\kimball\Trunk\NServiceBus\clin.ServiceBus\clin.Web.CatalogChangeEndpoint\CatalogChangeEndpoint.cs:line 26
   at NServiceBus.Unicast.UnicastBus.<>c__DisplayClass1d.<Start>b__1b() in y:\BuildAgent\work\31f8c64a6e8a2d7c\src\NServiceBus.Core\Unicast\UnicastBus.cs:line 804 could not be started.

我的创业班:

class ServerEndpoint : IWantToRunWhenBusStartsAndStops
{
    public ServerEndpoint(StructureMap.IContainer container)
    {
        _container = container;
    }

    public void Start()
    {
        Integration.Commerce.Initialization.InitCommerceServices(_container);
        Integration.Commerce.Catalog.InitCommerceCatalog();
    }

    public void Stop() { }

    public IContainer _container { get; set; }
 }

初始化例程:

public static void InitCommerceServices(IContainer container)
{
   var locator = new EPiServer.ServiceLocation.StructureMapServiceLocator(container);
   var context = new EPiServer.ServiceLocation.ServiceConfigurationContext(HostType.Undefined, container);
   new Mediachase.Commerce.Initialization.CommerceInitialization().ConfigureContainer(context);
   EPiServer.ServiceLocation.ServiceLocator.SetLocator(locator);
}

端点配置:

public class EndpointConfig : IConfigureThisEndpoint, IWantCustomInitialization, AsA_Server
{
    public void Init()
    {
        Configure.Serialization.Json();
        Configure.With()
            .StructureMapBuilder()
            .DefiningCommandsAs(MsgConvention.MessageConventions.IsCommandType)
            .DefiningEventsAs(MsgConvention.MessageConventions.IsEventType)
            .DefiningMessagesAs(MsgConvention.MessageConventions.IsInternalMessage);
    }
}

我没有在 Web 应用程序中运行此代码(显然?)。

我已执行以下操作来尝试解决问题:

  • 检查引用程序集的版本是否存在冲突
  • 在 InitCommerceServices 中创建一个本地容器变量,例如 container = StructureMap.ObjectFactory.Container;,而不是使用依赖注入。

【问题讨论】:

  • 你能发布堆栈跟踪吗?
  • @John 感谢您的浏览。很抱歉浪费您的时间。

标签: initialization nservicebus structuremap episerver episerver-7


【解决方案1】:

原来是不同版本的 StructureMap 之间存在冲突。 (有many meanings to System.EntryPointNotFoundException)。原始的 StructureMap dll 来自 EPiServer,并安装在 GAC 中。较新的 StructureMap 来自 NServiceBus 的 StructureMap nuget 包。我通过在&lt;configuration&gt;/&lt;runtime&gt; 元素下的每个端点的 App.config 中添加绑定重定向来解决两个版本之间的冲突,如 in this msdn page 所述

<assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
    <dependentAssembly>
    <assemblyIdentity name="StructureMap" publicKeyToken="e60ad81abae3c223" culture="neutral" />
        <bindingRedirect oldVersion="0.0.0.0-2.6.4.0" newVersion="2.6.4.0" />
    </dependentAssembly>
</assemblyBinding>

旁注: NuGet 应该在您升级包时自动为您添加绑定重定向。我不知道在安装软件包而不是升级时是否会这样做。因为我们使用的是 SlowCheetah,所以我永远不会知道它在这种情况下是否会这样做。配置文件转换使用我们自己的文件作为源 App.config,并且在生成时会覆盖文件。 (也许这个问题为使用原始文件作为 SlowCheetah 转换的来源提供了依据。)

【讨论】:

猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2014-05-10
  • 1970-01-01
  • 1970-01-01
  • 2011-09-18
相关资源
最近更新 更多