Questo contenuto non è disponibile nella lingua selezionata.
Chapter 1. Configuring single-supplier replication using the command line
In a single-supplier replication environment, one writable supplier replicates data to one or multiple read-only consumers. For example, set up single-supplier replication if a suffix receives a large number of search requests but only a small number of write requests. To distribute the load, clients can then search for the suffix on read-only consumers and send write requests to the supplier.
			This section assumes that you have an existing Directory Server instance running on a host named supplier.example.com that will act as a supplier in the replication topology to be set up. The procedures describe how to add a read-only consumer named consumer.example.com to the topology, and how to configure single-supplier replication for the dc=example,dc=com suffix.
		
1.1. Preparing the new consumer using the command line
				To prepare the consumer.example.com host, enable replication. This process:
			
- 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" - # dsconf <consumer_instance_name> replication enable --suffix "dc=example,dc=com" --role "consumer" --bind-dn "cn=replication manager,cn=config" --bind-passwd "password"- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - This command configures the - consumer.example.comhost as a consumer for the- dc=example,dc=comsuffix. Additionally, the command creates the- cn=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: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 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
				To prepare the supplier.example.com host, you need to:
			
- Enable replication for the suffix.
- Create a replication agreement 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 1 - # dsconf <supplier_instance_name> replication enable --suffix "dc=example,dc=com" --role "supplier" --replica-id 1- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - This command configures the - supplier.example.comhost as a supplier for the- dc=example,dc=comsuffix, and sets the replica ID of this entry to- 1.Important- The replica ID must be a unique integer between - 1and- 65534for 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-agreement - # 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-agreement- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - This 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: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 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-agreement - # dsconf <supplier_instance_name> repl-agmt init-status --suffix "dc=example,dc=com" example-agreement Agreement successfully initialized.- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Display the replication status: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Verify the - Replication Statusand- Last 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 to- 7200(2 hours), enter:- dsconf<supplier_instance_name> config replace nsslapd-idletimeout=7200 - # dsconf<supplier_instance_name> config replace nsslapd-idletimeout=7200- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - To set an unlimited period, set - nsslapd-idletimeoutto- 0.