In versions prior to 8.0.0.0, each load-balancing algorithm had to be explicitly configured with a set of backend servers. This is still supported, and may be the preferred configuration in some cases. For example, this is required if any backend server is not a Directory Server, or if it is a Directory Server prior to version 8.0.0.0. It may also be preferable if you wish to have more direct control over the configuration that the PingDirectoryProxy Server uses for each backend server.
Beginning with version 8.0.0.0, it is possible to configure the fewest operations and failover load-balancing algorithms so that they can automatically discover the appropriate set of backend servers from information in the topology registry. To do this, the load-balancing algorithm should be configured with a value for the ldap-external-server-template property rather than with one or more values for the backend-server property.
dsconfig create-load-balancing-algorithm \
--algorithm-name fewest-operations-load-balancer \
--type fewest-operations \
--set enabled:true \
--set ldap-external-server-template:dc_example_dc_com
dsconfig create-load-balancing-algorithm \
--algorithm-name failover-load-balancer \
--type failover \
--set enabled:true \
--set ldap-external-server-template:dc_example_dc_com
Note that with the failover load-balancing algorithm, the backend servers will be ordered lexicographically by instance name. This ensures that all PingDirectoryProxy Server instances will have a consistent ordering, but it is not as easy to control the ordering when automatically discovering backend servers as when they are explicitly configured. This is acceptable in many cases, as the primary use of failover load-balancing is often to avoid replication and unique attribute conflicts for write operations, and potentially to avoid read-after-write issues. However, if you wish to direct all traffic to a specific instance as long as it is available, then it may be better to explicitly configure the set of backend servers rather than use automatic discovery.
- Creating a failover load-balancing algorithm instance for write operations
- Creating a fewest operations load-balancing algorithm instance for read operations
- Creating a criteria-based load-balancing algorithm instance that uses failover load-balancing for write operations
- Configuring the proxying request processor to use the above criteria-based load balancing algorithm for writes and the fewest operations load-balancing algorithm for everything else
# Create a health check to verify that the dc=example,dc=com entry can be
# retrieved in a timely manner.
dsconfig create-ldap-health-check \
--check-name dc_example_dc_com-retrieve-base-entry \
--type search \
--set enabled:true \
--set base-dn:dc=example,dc=com \
--set allow-no-entries-returned:false \
--set allow-multiple-entries-returned:false
# Create a health check to verify that replication is working without a
# significant backlog.
dsconfig create-ldap-health-check \
--check-name dc_example_dc_com-replication-backlog \
--type replication-backlog \
--set enabled:true \
--set base-dn:dc=example,dc=com
# Create an LDAP external server template with the above
dsconfig create-ldap-external-server-template \
--template-name dc_example_dc_com \
--set health-check:dc_example_dc_com-retrieve-base-entry \
--set health-check:dc_example_dc_com-replication-backlog
# Create a fewest operations failover load-balancing algorithm instance that
# uses the default LDAP external server template for backend servers that it
# discovers from the topology registry.
dsconfig create-load-balancing-algorithm \
--algorithm-name dc_example_dc_com-fewest-operations \
--type fewest-operations \
--set enabled:true \
--set ldap-external-server-template:dc_example_dc_com
# Create a failover load-balancing algorithm instance that also uses the
# default LDAP external server template for backend servers that it
# discovers from the topology registry.
dsconfig create-load-balancing-algorithm \
--algorithm-name dc_example_dc_com-failover \
--type failover \
--set enabled:true \
--set ldap-external-server-template:dc_example_dc_com
# Create a criteria-based load-balancing algorithm instance that will use
# failover load-balancing for writes.
dsconfig create-criteria-based-load-balancing-algorithm \
--algorithm-name failover-for-writes \
--set load-balancing-algorithm:dc_example_dc_com-failover \
--set "request-criteria:Write Requests"
# Create a proxying request processor instance that uses criteria-based load
# balancing to ensure that writes use a failover strategy, and the remaining
# read operations use a default fewest operations strategy.
dsconfig create-request-processor \
--processor-name dc_example_dc_com \
--type proxying \
--set load-balancing-algorithm:dc_example_dc_com-fewest-operations \
--set criteria-based-load-balancing-algorithm:failover-for-writes
# Create a subtree view to ensure that operations below "dc=example,dc=com"
# will use the above proxying request processor.
dsconfig create-subtree-view \
--view-name dc_example_dc_com \
--set "base-dn:dc=example,dc=com" \
--set request-processor:dc_example_dc_com
# Update the default client connection policy to include the above subtree
# view.
dsconfig set-client-connection-policy-prop \
--policy-name default \
--add subtree-view:dc_example_dc_com