7.4.6 Verifying the OUD Replication
Once all the pods created are visible as READY
(i.e.
1/1
), you can verify your replication across multiple Oracle Unified
Directory (OUD) instances.
To verify the replication group, connect to the container and issue an OUD administration
command to show the details. The name of the container can be found by issuing the
following:
kubectl get pods -n <namespace> -o jsonpath='{.items[*].spec.containers[*].name}'
For
example:kubectl get pods -n oudns -o jsonpath='{.items[*].spec.containers[*].name}'
The output will look similar to the
following:oud-ds-rs oud-ds-rs oud-ds-rs
Once you have the container name you can verify the replication status in the following
ways:
- Run dresplication inside the pod
- Using kubectl commands
Run dresplication Inside the Pod
- Run the following command to create a bash shell in the
pod:
For example:kubectl --namespace <namespace> exec -it -c <containername> <podname> -- bash
This will take you into the pod:kubectl --namespace oudns exec -it -c oud-ds-rs oud-ds-rs-0 -- bash
[oracle@oud-ds-rs-0 oracle]$
- From the prompt, use the dsreplication command to check the status of your
replication
group:
The output will look similar to the following. Enter credentials where prompted:cd /u01/oracle/user_projects/oud-ds-rs-0/OUD/bin ./dsreplication status --trustAll \ --hostname oud-ds-rs-0 --port 1444 --adminUID admin \ --dataToDisplay compat-view --dataToDisplay rs-connections
>>>> Specify Oracle Unified Directory LDAP connection parameters Password for user 'admin': Establishing connections and reading configuration ..... Done. dc=example,dc=com - Replication Enabled ======================================= Server : Entries : M.C. [1] : A.O.M.C. [2] : Port [3] : Encryption [4] : Trust [5] : U.C. [6] : Status [7] : ChangeLog [8] : Group ID [9] : Connected To [10] ---------------------:---------:----------:--------------:----------:----------------:-----------:----------:------------:---------------:--------------:------------------------------- oud-ds-rs-0:1444 : 202 : 0 : 0 : 1898 : Disabled : Trusted : -- : Normal : Enabled : 1 : oud-ds-rs-0:1898 : : : : : : : : : : : (GID=1) oud-ds-rs-1:1444 : 202 : 0 : 0 : 1898 : Disabled : Trusted : -- : Normal : Enabled : 1 : oud-ds-rs-1:1898 : : : : : : : : : : : (GID=1) oud-ds-rs-2:1444 : 202 : 0 : 0 : 1898 : Disabled : Trusted : -- : Normal : Enabled : 1 : oud-ds-rs-2:1898 : : : : : : : : : : : (GID=1) Replication Server [11] : RS #1 : RS #2 : RS #3 -------------------------------:-------:-------:------ oud-ds-rs-0:1898 : -- : Yes : Yes (#1) : : : oud-ds-rs-1:1898 : Yes : -- : Yes (#2) : : : oud-ds-rs-2:1898 : Yes : Yes : -- (#3) : : : [1] The number of changes that are still missing on this element (and that have been applied to at least one other server). [2] Age of oldest missing change: the age (in seconds) of the oldest change that has not yet arrived on this element. [3] The replication port used to communicate between the servers whose contents are being replicated. [4] Whether the replication communication initiated by this element is encrypted or not. [5] Whether the directory server is trusted or not. Updates coming from an untrusted server are discarded and not propagated. [6] The number of untrusted changes. These are changes generated on this server while it is untrusted. Those changes are not propagated to the rest of the topology but are effective on the untrusted server. [7] The status of the replication on this element. [8] Whether the external change log is enabled for the base DN on this server or not. [9] The ID of the replication group to which the server belongs. [10] The replication server this server is connected to with its group ID between brackets. [11] This table represents the connections between the replication servers. The headers of the columns use a number as identifier for each replication server. See the values of the first column to identify the corresponding replication server for each number.
- Type
exit
to exit the pod.
Using kubectl commands
To verify the replication using kubectl commands:
- The
dsreplication status
command can be invoked using the following kubectl command:
For example:kubectl --namespace <namespace> exec -it -c <containername> <podname> -- \ /u01/oracle/user_projects/<OUD Instance/Pod Name>/OUD/bin/dsreplication status \ --trustAll --hostname <OUD Instance/Pod Name> --port 1444 --adminUID admin \ --dataToDisplay compat-view --dataToDisplay rs-connections
The output will be the same as in Run dresplication Inside the Pod above.kubectl --namespace oudns exec -it -c oud-ds-rs oud-ds-rs-0 -- \ /u01/oracle/user_projects/oud-ds-rs-0/OUD/bin/dsreplication status \ --trustAll --hostname oud-ds-rs-0 --port 1444 --adminUID admin \ --dataToDisplay compat-view --dataToDisplay rs-connections