private static void ValidateMasterNodeConfigurationForWorker(Configure config) { var masterNodeName = config.GetMasterNode(); if (masterNodeName == null) { throw new ConfigurationErrorsException( "When defining Worker profile, 'MasterNodeConfig' section must be defined and the 'Node' entry should point to a valid host name."); } switch (IsLocalIpAddress(masterNodeName)) { case true: Address.InitializeLocalAddress(Address.Local.SubScope(Guid.NewGuid().ToString()).ToString()); logger.WarnFormat("'MasterNodeConfig.Node' points to a local host name: [{0}]. Worker input address name is [{1}]. It is randomly and uniquely generated to allow multiple workers working from the same machine as the Distributor.", masterNodeName, Address.Local); break; case false: logger.InfoFormat("'MasterNodeConfig.Node' points to a non-local valid host name: [{0}].", masterNodeName); break; case null: throw new ConfigurationErrorsException( string.Format("'MasterNodeConfig.Node' entry should point to a valid host name. Currently it is: [{0}].", masterNodeName)); } }
public static Configure AzureMessageQueue(this Configure config) { CloudQueueClient queueClient; var configSection = Configure.GetConfigSection <AzureQueueConfig>(); Address.InitializeAddressMode(AddressMode.Remote); if (configSection != null) { queueClient = CloudStorageAccount.Parse(configSection.ConnectionString).CreateCloudQueueClient(); Address.OverrideDefaultMachine(configSection.ConnectionString); if (configSection.QueuePerInstance) { Configure.Instance.CustomConfigurationSource(new IndividualQueueConfigurationSource(Configure.ConfigurationSource)); } } else { queueClient = CloudStorageAccount.DevelopmentStorageAccount.CreateCloudQueueClient(); Address.OverrideDefaultMachine(NServiceBus.Unicast.Queuing.Azure.AzureMessageQueue.DefaultConnectionString); } config.Configurer.RegisterSingleton <CloudQueueClient>(queueClient); config.Configurer.ConfigureComponent <AzureMessageQueue>(DependencyLifecycle.SingleInstance) .ConfigureProperty(p => p.PurgeOnStartup, ConfigurePurging.PurgeRequested); if (configSection != null) { Configure.Instance.Configurer.ConfigureProperty <AzureMessageQueue>(t => t.PurgeOnStartup, configSection.PurgeOnStartup); Configure.Instance.Configurer.ConfigureProperty <AzureMessageQueue>(t => t.MaximumWaitTimeWhenIdle, configSection.MaximumWaitTimeWhenIdle); Configure.Instance.Configurer.ConfigureProperty <AzureMessageQueue>(t => t.MessageInvisibleTime, configSection.MessageInvisibleTime); Configure.Instance.Configurer.ConfigureProperty <AzureMessageQueue>(t => t.PeekInterval, configSection.PeekInterval); } if (configSection != null && !string.IsNullOrEmpty(configSection.QueueName)) { Configure.Instance.DefineEndpointName(configSection.QueueName); } else if (RoleEnvironment.IsAvailable) { Configure.Instance.DefineEndpointName(RoleEnvironment.CurrentRoleInstance.Role.Name); } Address.InitializeLocalAddress(Configure.EndpointName); return(config); }
public static Configure AzureServiceBusMessageQueue(this Configure config) { var configSection = Configure.GetConfigSection <AzureServiceBusQueueConfig>(); if (configSection == null) { throw new ConfigurationErrorsException("No AzureServiceBusQueueConfig configuration section found"); } Address.InitializeAddressMode(AddressMode.Remote); var credentials = TokenProvider.CreateSharedSecretTokenProvider(configSection.IssuerName, configSection.IssuerKey); var serviceUri = ServiceBusEnvironment.CreateServiceUri("sb", configSection.ServiceNamespace, string.Empty); var namespaceClient = new NamespaceManager(serviceUri, credentials); var factory = MessagingFactory.Create(serviceUri, credentials); Address.OverrideDefaultMachine(serviceUri.ToString()); config.Configurer.RegisterSingleton <NamespaceManager>(namespaceClient); config.Configurer.RegisterSingleton <MessagingFactory>(factory); config.Configurer.ConfigureComponent <AzureServiceBusMessageQueue>(DependencyLifecycle.SingleInstance); Configure.Instance.Configurer.ConfigureProperty <AzureServiceBusMessageQueue>(t => t.LockDuration, TimeSpan.FromMilliseconds(configSection.LockDuration)); Configure.Instance.Configurer.ConfigureProperty <AzureServiceBusMessageQueue>(t => t.MaxSizeInMegabytes, configSection.MaxSizeInMegabytes); Configure.Instance.Configurer.ConfigureProperty <AzureServiceBusMessageQueue>(t => t.RequiresDuplicateDetection, configSection.RequiresDuplicateDetection); Configure.Instance.Configurer.ConfigureProperty <AzureServiceBusMessageQueue>(t => t.RequiresSession, configSection.RequiresSession); Configure.Instance.Configurer.ConfigureProperty <AzureServiceBusMessageQueue>(t => t.DefaultMessageTimeToLive, TimeSpan.FromMilliseconds(configSection.DefaultMessageTimeToLive)); Configure.Instance.Configurer.ConfigureProperty <AzureServiceBusMessageQueue>(t => t.EnableDeadLetteringOnMessageExpiration, configSection.EnableDeadLetteringOnMessageExpiration); Configure.Instance.Configurer.ConfigureProperty <AzureServiceBusMessageQueue>(t => t.DuplicateDetectionHistoryTimeWindow, TimeSpan.FromMilliseconds(configSection.DuplicateDetectionHistoryTimeWindow)); Configure.Instance.Configurer.ConfigureProperty <AzureServiceBusMessageQueue>(t => t.MaxDeliveryCount, configSection.MaxDeliveryCount); Configure.Instance.Configurer.ConfigureProperty <AzureServiceBusMessageQueue>(t => t.EnableBatchedOperations, configSection.EnableBatchedOperations); if (!string.IsNullOrEmpty(configSection.QueueName)) { Configure.Instance.DefineEndpointName(configSection.QueuePerInstance ? QueueIndividualizer.Individualize(configSection.QueueName) : configSection.QueueName); } else if (RoleEnvironment.IsAvailable) { Configure.Instance.DefineEndpointName(RoleEnvironment.CurrentRoleInstance.Role.Name); } Address.InitializeLocalAddress(Configure.EndpointName); return(config); }
/// <summary> /// Configures a queue per instance /// </summary> /// <param name="config"></param> /// <returns></returns> public static Configure QueuePerInstance(this Configure config) { Configure.Instance.DefineEndpointName(QueueIndividualizer.Individualize(Configure.EndpointName)); Address.InitializeLocalAddress(Configure.EndpointName); return(config); }