Dieser Inhalt ist in der von Ihnen ausgewählten Sprache nicht verfügbar.
Chapter 1. Configuring single-supplier replication using the command line
Configure single-supplier replication in Directory Server to synchronize data from a central source to read-only consumers. The topology with a single-supplier distributes search traffic across multiple servers and reduces the load on the primary supplier while ensuring data availability for clients.
The single-supplier replication topology is beneficial when a suffix on the supplier receives many search requests but few write operations.
Provided example procedures assume that you have an existing Directory Server instance supplier.example.com that acts as a supplier in the replication topology being set up. Add a read-only consumer named consumer.example.com to the topology, then configure single-supplier replication for the dc=example,dc=com suffix.
1.1. Preparing the new consumer using the command line Link kopierenLink in die Zwischenablage kopiert!
Prepare a new consumer in Directory Server to receive directory updates from a supplier. You can establish a secure connection for incoming data updates by using the command line to define the consumer role and set appropriate permissions.
To prepare the consumer.example.com host, enable replication which achieves the following:
- Configures the role of this server in the replication topology
- Defines the suffix that is replicated
- Creates the replication manager account the supplier uses to connect to this host
Perform this procedure on the consumer that you want to add to the replication topology.
Prerequisites
- You installed the Directory Server instance. For details, see Setting up a new instance on the command line using a .inf file.
-
The database for the
dc=example,dc=comsuffix exists.
Procedure
Enable replication for the
dc=example,dc=comsuffix:# dsconf <consumer_instance_name> replication enable --suffix "dc=example,dc=com" --role "consumer" --bind-dn "cn=replication manager,cn=config" --bind-passwd "<password>"This command configures the
consumer.example.comhost as a consumer for thedc=example,dc=comsuffix. Additionally, the command creates thecn=replication manager,cn=configuser with the specified password and allows this account to replicate changes for the suffix to this host.
Verification
Display the replication configuration:
# dsconf <consumer_instance_name> replication get --suffix "dc=example,dc=com"dn: cn=replica,cn=dc\3Dexample\2Cdc\3Dcom,cn=mapping tree,cn=config ... nsDS5ReplicaBindDN: cn=replication manager,cn=config nsDS5ReplicaRoot: dc=example,dc=com nsDS5ReplicaType: 2 ...These parameters indicate:
-
nsDS5ReplicaBindDNspecifies the replication manager account. -
nsDS5ReplicaRootsets the suffix that is replicated. -
nsDS5ReplicaTypeset to2defines that this host is a consumer.
-
1.2. Configuring the existing server as a supplier to the consumer using the command line Link kopierenLink in die Zwischenablage kopiert!
Configure an existing Directory Server instance as a supplier to distribute updates to a consumer. You can establish a replication agreement by using the command line to define supplier roles, bind credentials, and connection parameters for the directory environment.
To prepare the supplier.example.com host, you need to do the following:
- Enable replication for the suffix.
- Create a replication agreement that points to the consumer.
- Initialize the consumer.
Perform this procedure on the existing supplier in the replication topology.
Prerequisites
-
You enabled replication for the
dc=example,dc=comsuffix on the consumer.
Procedure
Enable replication for the
dc=example,dc=comsuffix:# dsconf <supplier_instance_name> replication enable --suffix "dc=example,dc=com" --role "supplier" --replica-id 1This command configures the
supplier.example.comhost as a supplier for thedc=example,dc=comsuffix, and sets the replica ID of this entry to1.ImportantThe replica ID must be a unique integer between
1and65534for a suffix across all suppliers in the topology.Add the replication agreement and initialize the consumer:
# dsconf <supplier_instance_name> repl-agmt create --suffix "dc=example,dc=com" --host "consumer.example.com" --port 389 --conn-protocol=LDAP --bind-dn "cn=replication manager,cn=config" --bind-passwd "<password>" --bind-method=SIMPLE --init example-agreementThis command creates a replication agreement named
example-agreement. The replication agreement defines settings, such as the consumer’s host name, protocol, and authentication information that the supplier uses when connecting and replicating data to this consumer.After the agreement was created, Directory Server initializes
consumer.example.com. Depending on the amount of data to replicate, initialization can be time-consuming.
Verification
Display the replication configuration:
# dsconf <supplier_instance_name> replication get --suffix "dc=example,dc=com"dn: cn=replica,cn=dc\3Dexample\2Cdc\3Dcom,cn=mapping tree,cn=config ... nsDS5ReplicaRoot: dc=example,dc=com nsDS5ReplicaType: 3 ...These parameters indicate:
-
nsDS5ReplicaRootsets the suffix that is replicated. -
nsDS5ReplicaTypeset to3defines that this host is a supplier.
-
Verify whether the initialization was successful:
# dsconf <supplier_instance_name> repl-agmt init-status --suffix "dc=example,dc=com" example-agreementAgreement successfully initialized.Display the replication status:
# dsconf <supplier_instance_name> repl-agmt status --suffix "dc=example,dc=com" example-agreementStatus For Agreement: "example-agreement" (consumer.example.com:389) Replica Enabled: on Update In Progress: FALSE Last Update Start: 20210330075608Z Last Update End: 20210330075608Z Number Of Changes Sent: 1:3/0 Number Of Changes Skipped: None Last Update Status: Error (0) Replica acquired successfully: Incremental update succeeded Last Init Start: 20210330074603Z Last Init End: 20210330074606Z Last Init Status: Error (0) Total update succeeded Reap Active: 0 Replication Status: Not in Synchronization: supplier (6062d73c000000010000) consumer (Unavailable) State (green) Reason (error (0) replica acquired successfully: incremental update succeeded) Replication Lag Time: UnavailableVerify the
Replication StatusandLast Update Statusfields.
Troubleshooting
By default, the replication idle timeout for all agreements on a server is 1 hour. If the initialization of large databases fails due to timeouts, set the
nsslapd-idletimeoutparameter to a higher value. For example, to set the parameter to7200(2 hours), enter:# dsconf<supplier_instance_name> config replace nsslapd-idletimeout=7200To set an unlimited period, set
nsslapd-idletimeoutto0.