Configuring System-Level Replication Settings
You can perform the following system-level replication configuration tasks:
- Configuring Replication Mates
- Configuring Replication Config-Sync Bridges
- Configuring Replication Interfaces
- Configuring TLS/SSL for Replication
- Configuring Replication Compatibility Mode for Transactions
Configuring Replication Mates
The replication facility requires that the event brokers at both replication sites know of their respective replication mates. For the event brokers at each replication site, you must indicate the virtual router name used by their replication mates and the address to use to connect to them. You can also configure whether the event brokers’ connect ports will use compressed or non-compressed data. (If no connect port configuration is provided, the default setting of non-compressed is used.)
Replication mate information that is set at the system level is applied to all Message VPNs on that event broker.
To configure replication mates, replication service must be disabled for each Message VPN on the event broker (refer to Monitoring Replication).
Configuring Replication Mates for Appliances
When indicating a replication mate for an appliance, a combination of the virtual router name and a unique address is used. The port number and type of connection (plain text, SSL, or compressed) used is set separately.
Setting Replication Mate Virtual Router Names and Connect Addresses
To set the virtual router name and unique address used for the replication mate, enter the following CONFIG commands:
solace(configure/replication)# mate solace(configure/replication/mate)# virtual-router-name <virtual-router-name> connect-via <addr>
Where:
<virtual-router-name>
is the virtual router name of the replication mate. This name must begin with "v:", as that indicates a virtual router. Event broker names can contain up to 66 characters, composed of alphanumeric characters 0 to 9, a to z, A to Z, underscore '_', dot '.', and hyphen '-'. Note that '_', '.' and '-' cannot be used at the beginning or end of an event broker name. Event broker names must be unique among all configured event brokers.
<addr>
is the IP address or hostname of the mate event broker in the form IP_address[:port]
or hostname[:port]
, where the IP address is specified in the dotted decimal notation form nnn.nnn.nnn.nnn
and port
is the port number on the replication mate virtual router.
The no version of this command, no mate
, removes a configured replication mate.
Setting Replication Mate Connect Ports
To set a connect port for a replication mate's virtual router, enter the following CONFIG command:
solace(configure/replication)# mate solace(configure/replication/mate)# connect-port <port> [compressed] [ssl]
Where:
<port>
is the port number on the replication mate virtual router. This number is specified as a decimal value from 0 to 65535. This command does not need to be executed if the default values are appropriate. Default values are 55555 for non-compressed data, 55003 for compressed data, and 55443 for TLS/SSL data.
compressed
indicates that the port is for compressed data traffic.
ssl
indicates that the port is for TLS/SSL data traffic.
Configuring Replication Mates for Software Event Brokers
When indicating a replication mate for a software event broker, the virtual router name of the replication mate is set separately from its connect-via information, which provides a unique combination of an address, a port, and the type of connection (plain text, SSL, or compressed).
Configuring the connect-via information separately allows you to set multiple connect addresses for the virtual router used by the replication mate. This is important, for example, if the replication mate is in an event broker HA pair with host list takeover mode. In this case, you must set a connect-via address for both the primary and standby nodes.
Setting Replication Mate Virtual Router Names
To configure the virtual router name for the replication mate, enter the following CONFIG commands:
solace(configure/replication)# mate solace(configure/replication/mate)# virtual-router-name <virtual-router-name>
Where:
<virtual-router-name>
is the name of the virtual router where the specified replication mate is located. This name must begin with "v:", as that indicates a virtual router, and it must match the virtual router name of the replication mate. Event broker names can contain up to 66 characters, composed of alphanumeric characters 0 to 9, a to z, A to Z, underscore '_', dot '.', and hyphen '-'. '-'. Note that '_', '.' and '-' cannot be used at the beginning or end of an event broker name. Event broker names must be unique among all configured event brokers.
The no version of this command, no mate
, removes a configured replication mate.
If the replication mate is in an event broker HA pair, use the virtual router name of the primary event broker in the HA pair.
Configuring Replication Mate Connect Addresses and Ports
To configure a unique address and connect port for a replication mate’s virtual router, enter the following CONFIG command:
solace(configure/replication)# mate solace(configure/replication/mate)# connect-via <addr-port> [compressed] [ssl]
Where:
<addr-port>
is the IP address or hostname of the event broker in the form IP_address:port
or hostname:port
, where the IP address is specified in the dotted decimal notation form nnn.nnn.nnn.nnn
and port
is the port number on the replication mate virtual router (specified as a decimal value from 0 to 65535).
compressed
indicates that the port is for compressed data traffic.
ssl
indicates that the port is for TLS/SSL data traffic.
In this example, the mate replication site that uses the virtual name solace1-site2
is provided with two connect-via addresses for TLS/SSL data traffic.
solace1-site1(configure/replication/mate)# connect-via 192.168.132.26:55443 ssl solace1-site1(configure/replication/mate)# connect-via 192.168.132.31:55443 ssl solace1-site1(configure/replication/mate)# show replication Replication Interface: Replication Mate: v:solace1-site2 Plain Text: Compressed: SSL: 192.168.132.26:55443 192.168.132.31:55443
Configuring Replication Config-Sync Bridges
When replication is enabled on an event broker, a replication Config-Sync bridge is automatically created from one replication site to its mate. You can modify the default Config-Sync parameters for this replication Config-Sync bridge. The configuration tasks that you can perform are:
- Setting Authentication Schemes
- Enabling Data Compression
- Configuring Message Spool Window Sizes
- Configuring Retry Delay Times
- Enabling SSL
- Configuring SSL Server Certificate Validation
- Enabling Replication Config-Sync Bridges
Setting Authentication Schemes
Replication Config-Sync bridges can be configured to use authenticated connections. Basic and client certificate authentication modes are available.
To configure the authentication scheme to be used for replication Config-Sync bridge connections, enter the following CONFIG commands:
solace(configure)# replication solace(configure/replication)# config-sync bridge solace(configure/replication/config-sync/bridge)# authentication auth-scheme {basic | client-certificate}
Where:
basic
specifies that basic username and password authentication should be used for Config-Sync bridge connections.
client-certificate
specifies that client certificate authentication should be used for Config-Sync bridge connections.
When client certificate authentication is used, remote event brokers will treat the server certificate of the event broker as a client certificate. Therefore, the server certificate of an event broker should adhere to the Config-Sync client certificate authentication settings that are set on the remote event broker.
Enabling Data Compression
By default, no compression is applied to data transferred over the replication Config-Sync bridge.
To enable data compression, enter the following CONFIG command:
solace(configure)# replication solace(configure/replication)# config-sync bridge solace(configure/replication/config-sync/bridge)# compressed-data
When data compression is enabled for the bridge, compressed ports must be configured in the replication mate (see Configuring Replication Mates).
If compression is enabled along with SSL for the bridge, the SSL port must be configured in the replication mate.
The no
version, no compressed-data
, disables data compression.
Configuring Message Spool Window Sizes
The default value for a replication Config-Sync bridge’s message spool window size is expected to work well in most typical deployments. Configuring an excessively large message spool window size can negatively impact network performance. Before changing this parameter, contact Solace for assistance in choosing the appropriate value for your network conditions.
The message spool window size dictates how many outstanding Config-Sync messages may be sent over a replication Config-Sync bridge before the active replication site must receive an acknowledgment.
To configure the message spool window size, enter the following CONFIG command:
solace(configure)# replication solace(configure/replication)# config-sync bridge solace(configure/replication/config-sync/bridge)# message-spool solace(...tion/config-sync/bridge/message-spool)# window-size <number>
Where:
<number>
is an integer from 1 to 65535 that sets how many messages can be in the window. The default value is 65535.
The no version of this command (no message-spool window-size) resets the message spool window size value back to the default value.
Configuring Retry Delay Times
To configure the amount of time that must pass before retrying a connection to the replication mate over the replication Config-Sync bridge, enter the following CONFIG command:
solace(configure)# replication solace(configure/replication)# config-sync bridge solace(configure/replication/config-sync/bridge)# retry-delay <seconds>
Where:
<seconds>
is an integer from 1 to 255 that specifies the number of seconds to wait before retrying a connection to the replication mate. The default is 3.
The no version of this command (no retry-delay) resets the number of seconds to wait back to the default value.
Enabling SSL
TLS/SSL encryption can be enabled on replication Config-Sync bridges to enable secure connections between event brokers that use Config-Sync.
To enable TLS/SSL for replication Config-Sync bridge connections, enter the following CONFIG command:
solace(configure)# replication solace(configure/replication)# config-sync bridge solace(configure/replication/config-sync/bridge)# ssl
- After TLS/SSL is enabled on the replication Config-Sync bridges, for authentication using SSL to succeed, the following must be also be configured:
- an SSL server certificate on the remote event broker
- a matching trusted CA on the local event broker
- the connect port used for the replication mate must be set as SSL
- When SSL is enabled for the bridge, the replication mates that you set must use SSL connection ports (see Configuring Replication Mates).
The no version of this command, no ssl
, disables SSL encryption on replication Config-Sync bridges.
Configuring SSL Server Certificate Validation
You can configure server certificate validation settings for replication Config-Sync bridges to make certificate validation more secure or less secure.
To configure SSL server certificate validation settings, enter the following CONFIG command:
solace(configure)# replication solace(configure/replication)# config-sync bridge solace(configure/replication/config-sync/bridge)# ssl-server-certificate-validation
The CLI is now at the configuration mode to configure SSL server certificate validation settings for replication Config-Sync bridges. From here, you can configure the following parameters:
- validate-server-name
- max-certificate-chain-depth
- validate-certificate-date
For descriptions of these parameters, refer to Configuring Server Certificate Validation Settings.
Enabling Replication Config-Sync Bridges
- To enable the replication Config-Sync bridge, enter the following CONFIG command:
solace(configure/replication/config-sync/bridge)# no shutdown
- To disable the replication Config-Sync bridge, enter the following CONFIG command:
solace(configure/replication/config-sync/bridge)# shutdown
Enabling Server Name Validation for Replication Config-Sync Bridges
You can enable or disable the TLS authentication mechanism to verify the name used to connect to the remote broker. If enabled, the server name used for that connection is verified against the server names in the Subject Alternative Name (SAN) extension in the certificate returned from the remote broker.
Server name validation is enabled by default and should remain enabled in all production scenarios.
To enable validation of server names for replication Config-Sync bridges, enter the following commands:
solace(configure)# replication
solace(configure/replication)# config-sync bridge ssl-server-certificate-validation
solace(...dge/ssl-server-certificate-validation)# validate-server-name
To disable server name validation:
solace(...dge/ssl-server-certificate-validation)# no validate-server-name
Configuring Replication Interfaces
You can specify the physical network interface from which connections to the replication mate will originate. If no physical network interface is specified, an appropriate interface is automatically assigned.
To configure a specific replication interface for the event broker, enter the following CONFIG command:
solace(configure/replication)# interface <phys-intf>
Where:
<phys-intf>
is an ASCII string specifying the physical Ethernet interface port or LAG of the local event broker. Valid values are <cartridge>/<slot>/<port>
(for example, 1/1/8); <cartridge>/<slot>/lag<N>
(for example, 1/1/lag1). Only a single LAG numbered 1 is supported.
The no version of this command, no interface <phys-intf>
, removes a configured replication interface.
If you are using an HA redundant event broker pair, do not specify a replication interface if the configured interfaces for the HA pair do not match. If a replication interface is specified that does not exist on the mate event broker, when Config-Sync is enabled it will enter a blocked state on the mate because the non-existent interface cannot be configured.
Configuring TLS/SSL for Replication
If you are using TLS/SSL encryption with replication, you can configure the cipher suites that the replication facility will use for authentication as well as the list of security certificates that replication links will accept.
Configuring Cipher Suites for Replication Connections
Any number of cipher suites can be used for encryption . These cipher suites are ordered from most secure to least secure. (For a full list of cipher suites supported by the event broker, refer to Supported Cipher Suites.)
By default, the entire list of cipher suites is used, for the strongest possible encryption. You may configure the feature to only use certain cipher suites.
To configure which cipher suites should be use on replication connections, enter the following CONFIG CLI commands:
solace(configure/replication)# ssl solace(configure/replication/ssl)# cipher-suite {default | empty | name <suite-name> [{before | after} <existing-suite-name>]}
Where:
default
specifies that the default list of cipher suites (that is, all of the cipher suites) should be used.
empty
removes all cipher suites from the list.
name <suite-name>
adds the specified cipher suite to the list of suites to be used.
before <existing-suite-name>
specifies that the suite specified by the name
parameter should be inserted into the list immediately before (that is, with a higher priority than) the suite specified by the before
parameter.
after <existing-suite-name>
specifies that the suite specified by the name
parameter should be inserted into the list immediately after (that is, with a lower priority than) the suite specified by the after
parameter.
The no version of this command, no cipher suite name <suite-name>
, removes the specified cipher suite from the list of eligible cipher suites.
Configuring Replication Compatibility Mode for Transactions
In previous releases, there was limited support for the replication of local and XA transactions—Guaranteed messages published in transactions were propagated to the replication standby site, but not within transactions. The legacy behavior is maintained for backwards compatibility and is the default setting, but it has several undesirable consequences. It is strongly recommended that you use the transacted mode that replicates Guaranteed messages published in transactions.
Changing the compatibility mode will cause all in-flight transactions to be rolled back. This procedure should only be executed in a maintenance window.
To set the compatible mode to transacted, replication, enter the following CONFIG commands:
solace(configure/hardware/message-spool)# transaction replication-compatibility-mode <mode>
Where:
<mode>
is either legacy
or transacted
legacy
—all transactions originated by clients are replicated to the standby site without using transactionstransacted
—all transactions originated by clients are replicated to the standby site using transactionsReplication mates must use the same compatibility mode and the no version of this command sets the mode to legacy.
Changing Replication Compatibility Mode While In Service
If event brokers are currently providing replication service, then the order in which the mode is changed at the sites is important. Follow the order of operations below to prevent service disruption.
- To change from legacy to transacted mode:
- Change the standby site to transacted.
- Change the active site to transacted.
- To change from transacted to legacy mode (not recommended):
- Change the active site to legacy.
- Change the standby site to legacy.