-
Notifications
You must be signed in to change notification settings - Fork 106
How To Run OpenDJ in Kubernetes
This article describes how to deploy OpenDJ on Kubernetes. We will use OpenDJ Docker image from Docker Hub Registry https://hub.docker.com/r/openidentityplatform/opendj/
In this tutorial, we will use Minikube as a local Kubernetes cluster.
kubectl
should also be installed
Start Minikube with at least 4 cores, and 8 GB of memory to avoid insufficient resources errors.
minikube start --cpus=4 --memory=8g
The following service will be used for DNS lookups between OpenAM Pods and clients.
Create opendj-service.yaml
file with the following contents:
opendj-service.yaml
:
apiVersion: v1
kind: Service
metadata:
labels:
app: opendj
name: opendj
spec:
clusterIP: None
ports:
- port: 1389
name: ldap
- port: 1636
name: ldaps
- port: 4444
name: admin
selector:
app: opendj
Then create service in Kubernetes using kubectl
:
kubectl apply -f opendj-service.yaml
Make sure the service has been created:
kubectl get svc opendj
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
opendj ClusterIP None <none> 1389/TCP,1636/TCP,4444/TCP 39s
Create opendj-statefulset.yaml
file with the following contents:
opendj-statefulset.yaml
:
apiVersion: apps/v1
kind: StatefulSet
metadata:
name: opendj
labels:
app: opendj
spec:
serviceName: opendj
replicas: 1
selector:
matchLabels:
app: opendj
template:
metadata:
labels:
app: opendj
spec:
containers:
- name: opendj
image: openidentityplatform/opendj
imagePullPolicy: Always
ports:
- containerPort: 1389
protocol: TCP
- containerPort: 1636
protocol: TCP
- containerPort: 4444
protocol: TCP
resources: {}
terminationMessagePath: /dev/termination-log
terminationMessagePolicy: File
volumeMounts:
- name: opendj-data
mountPath: /opt/opendj/data
volumeClaimTemplates:
- metadata:
name: opendj-data
spec:
accessModes: [ "ReadWriteOnce" ]
resources:
requests:
storage: 1Gi
Create OpenDJ StatefulSet in Kubernetes
kubectl apply -f opendj-statefulset.yaml
Check if StatefulSet is wokring
kubectl get statefulset opendj
NAME READY AGE
opendj 1/1 2m
Wait for pod is created
Get created Pods
kubectl get pods -l="app=opendj"
NAME READY STATUS RESTARTS AGE
opendj-0 1/1 Running 0 2m42s
Lets check OpenDJ pod status
$ kubectl exec -it opendj-0 -- /opt/opendj/bin/status --bindDN "cn=Directory Manager" --bindPassword password
--- Server Status ---
Server Run Status: Started
Open Connections: 1
--- Server Details ---
Host Name: opendj-0.opendj.default.svc.cluster.local
Administrative Users: cn=Directory Manager
Installation Path: /opt/opendj
Instance Path: /opt/opendj/data
Version: OpenDJ Server 4.4.3
Java Version: 1.8.0_111
Administration Connector: Port 4444 (LDAPS)
--- Connection Handlers ---
Address:Port : Protocol : State
-------------:------------------------:---------
-- : LDIF : Disabled
0.0.0.0:161 : SNMP : Disabled
0.0.0.0:1389 : LDAP (allows StartTLS) : Enabled
0.0.0.0:1636 : LDAPS : Enabled
0.0.0.0:1689 : JMX : Disabled
0.0.0.0:8080 : HTTP : Disabled
--- Data Sources ---
Base DN: dc=example,dc=com
Backend ID: userRoot
Entries: 1
Replication:
OpenDJ is an LDAPv3 compliant directory service, which has been developed for the Java platform, providing a high performance, highly available, and secure store for the identities managed by your organization. Its easy installation process, combined with the power of the Java platform makes OpenDJ the simplest, fastest directory to deploy and manage.