4.8 KiB
						
					
					
				
			
		
		
	
	Distributed Event Bus RabbitMQ Integration
This document explains how to configure the RabbitMQ as the distributed event bus provider. See the distributed event bus document to learn how to use the distributed event bus system
Installation
Use the ABP CLI to add Volo.Abp.EventBus.RabbitMQ NuGet package to your project:
- Install the ABP CLI if you haven't installed before.
- Open a command line (terminal) in the directory of the .csprojfile you want to add theVolo.Abp.EventBus.RabbitMQpackage.
- Run abp add-package Volo.Abp.EventBus.RabbitMQcommand.
If you want to do it manually, install the Volo.Abp.EventBus.RabbitMQ NuGet package to your project and add [DependsOn(typeof(AbpEventBusRabbitMqModule))] to the ABP module class inside your project.
Configuration
You can configure using the standard configuration system, like using the appsettings.json file, or using the options classes.
appsettings.json file configuration
This is the simplest way to configure the RabbitMQ settings. It is also very strong since you can use any other configuration source (like environment variables) that is supported by the AspNet Core.
Example: The minimal configuration to connect to a local RabbitMQ server with default configurations
{
  "RabbitMQ": {
    "EventBus": {
      "ClientName": "MyClientName",
      "ExchangeName": "MyExchangeName"
    }
  }
}
- ClientNameis the name of this application, which is used as the queue name on the RabbitMQ.
- ExchangeNameis the exchange name.
See the RabbitMQ document to understand these options better.
Connections
If you need to connect to another server than the localhost, you need to configure the connection properties.
Example: Specify the host name (as an IP address)
{
  "RabbitMQ": {
    "Connections": {
      "Default": {
        "HostName": "123.123.123.123"
      }
    },
    "EventBus": {
      "ClientName": "MyClientName",
      "ExchangeName": "MyExchangeName"
    }
  }
}
Defining multiple connections is allowed. In this case, you can specify the connection that is used for the event bus.
Example: Declare two connections and use one of them for the event bus
{
  "RabbitMQ": {
    "Connections": {
      "Default": {
        "HostName": "123.123.123.123"
      },
      "SecondConnection": {
        "HostName": "321.321.321.321"
      }
    },
    "EventBus": {
      "ClientName": "MyClientName",
      "ExchangeName": "MyExchangeName",
      "ConnectionName": "SecondConnection"
    }
  }
}
This allows you to use multiple RabbitMQ server in your application, but select one of them for the event bus.
You can use any of the ConnectionFactory properties as the connection properties.
Example: Specify the connection port
{
  "RabbitMQ": {
    "Connections": {
      "Default": {
        "HostName": "123.123.123.123",
        "Port": "5672"
      }
    }
  }
}
If you need to connect to the RabbitMQ cluster, you can use the ; character to separate the host names.
Example: Connect to the RabbitMQ cluster
{
  "RabbitMQ": {
    "Connections": {
      "Default": {
        "HostName": "123.123.123.123;234.234.234.234"
      }
    },
    "EventBus": {
      "ClientName": "MyClientName",
      "ExchangeName": "MyExchangeName"
    }
  }
}
The Options Classes
AbpRabbitMqOptions and AbpRabbitMqEventBusOptions classes can be used to configure the connection strings and event bus options for the RabbitMQ.
You can configure this options inside the ConfigureServices of your module.
Example: Configure the connection
Configure<AbpRabbitMqOptions>(options =>
{
    options.Connections.Default.UserName = "user";
    options.Connections.Default.Password = "pass";
    options.Connections.Default.HostName = "123.123.123.123";
    options.Connections.Default.Port = 5672;
});
Example: Configure the client, exchange names and prefetchCount
Configure<AbpRabbitMqEventBusOptions>(options =>
{
    options.ClientName = "TestApp1";
    options.ExchangeName = "TestMessages";
    options.PrefetchCount = 1;
});
Using these options classes can be combined with the appsettings.json way. Configuring an option property in the code overrides the value in the configuration file.