我有两个工作者角色设置为nservicebus端点(nservicebus 3.2.8),并且两者都使用AzureDataBus配置来处理大于为azure队列分配的大小的消息。我的雇主不允许在配置中放置凭据,因此使用IProvideConfiguration配置存储凭据。
这似乎有效,但似乎nservicebus仍在尝试使用本地开发存储连接初始化数据总线通道,这导致worker角色重启几次。最终它启动并获取正确的配置。
关于我应该如何配置数据总线频道,我做错了吗?
以下是辅助角色事件日志的例外情况:
An unhandled exception occurred. Type: System.Exception Process ID: 2420
Process Name: WaWorkerHost
Thread ID: 6
AppDomain Unhandled Exception for role My.WorkerRole.Assembly_IN_1
Exception: Exception when starting endpoint, error has been logged. Reason: Unable to connect to the remote server
at NServiceBus.Hosting.GenericHost.Start()
at NServiceBus.Hosting.Azure.RoleEntryPoint.Run()
at Microsoft.WindowsAzure.ServiceRuntime.RoleEnvironment.StartRoleInternal()
at Microsoft.WindowsAzure.ServiceRuntime.Implementation.Loader.RoleRuntimeBridge.<StartRole>b__1()
at System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state, Boolean ignoreSyncCtx)
at System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state)
at System.Threading.ThreadHelper.ThreadStart()
Inner Exception: Unable to connect to the remote server
at Microsoft.WindowsAzure.StorageClient.Tasks.Task`1.get_Result()
at Microsoft.WindowsAzure.StorageClient.Tasks.Task`1.ExecuteAndWait()
at Microsoft.WindowsAzure.StorageClient.CloudBlobContainer.CreateIfNotExist(BlobRequestOptions options)
at NServiceBus.DataBus.Azure.BlobStorage.BlobStorageDataBus.Start()
at System.EventHandler.Invoke(Object sender, EventArgs e)
at NServiceBus.Unicast.UnicastBus.NServiceBus.IStartableBus.Start(Action startupAction)
at NServiceBus.Hosting.GenericHost.Start()
Inner Exception: No connection could be made because the target machine actively refused it 127.0.0.1:10000
at System.Net.Sockets.Socket.EndConnect(IAsyncResult asyncResult)
at System.Net.ServicePoint.ConnectSocketInternal(Boolean connectFailure, Socket s4, Socket s6, Socket& socket, IPAddress& address, ConnectSocketState state, IAsyncResult asyncResult, Int32 timeout, Exception& exception)
会立即导致流程终止:
Application: WaWorkerHost.exe
Framework Version: v4.0.30319
Description: The process was terminated due to an unhandled exception.
Exception Info: System.Exception
Stack:
at NServiceBus.Hosting.GenericHost.Start()
at NServiceBus.Hosting.Azure.RoleEntryPoint.Run()
at Microsoft.WindowsAzure.ServiceRuntime.RoleEnvironment.StartRoleInternal()
at Microsoft.WindowsAzure.ServiceRuntime.Implementation.Loader.RoleRuntimeBridge.<StartRole>b__1()
at System.Threading.ExecutionContext.Run(System.Threading.ExecutionContext, System.Threading.ContextCallback, System.Object, Boolean)
at System.Threading.ExecutionContext.Run(System.Threading.ExecutionContext, System.Threading.ContextCallback, System.Object)
at System.Threading.ThreadHelper.ThreadStart()
以下是我的终点配置:
internal class EndpointConfig : IConfigureThisEndpoint, AsA_Worker, IWantCustomInitialization
{
#region IWantCustomInitialization Members
public void Init()
{
Configure.With()
.DefaultBuilder()
.AzureConfigurationSource()
.MessageForwardingInCaseOfFault()
.AzureMessageQueue()
.JsonSerializer()
.AzureDataBus()
.AzureSubcriptionStorage()
.UnicastBus()
.DisableTimeoutManager()
.DisableSecondLevelRetries()
.IsTransactional(true)
.IsolationLevel(System.Transactions.IsolationLevel.ReadCommitted)
.PurgeOnStartup(false);
}
}
Databus配置覆盖:
public class ConfigOverride : IProvideConfiguration<AzureDataBusConfig>
{
AzureDataBusConfig IProvideConfiguration<AzureDataBusConfig>.GetConfiguration()
{
return new AzureDataBusConfig()
{
ConnectionString = "my storage key";
};
}
}
答案 0 :(得分:3)
听起来像初始化逻辑中的计时问题,基本上你在nsb应用配置覆盖之前调用AzureDataBus()并且你回退到默认设置。你可以尝试将IWantCustomInitialization放在一个单独的类中(而不是稍后运行)。
如果这没有帮助,请随时给我发一个小代表,我会看看它!
PS:你可以省略.With()。DefaultBuilder(),因为这是默认值!
亲切的问候, 伊夫