Instruction how to run CDS on Microk8s.
System Setup:
Make sure to have the correct versions of Kubernetes, kubectl and Helm installed to match the desired ONAP version. Find out required versions for onap e.g. from from https://docs.onap.org/projects/onap-oom/en/latest/submodules/oom.git/docs/oom_cloud_setup_guide.html. Guide is tested on a dedicated linux box (Ubuntu 18_04).
...
It is yet not clear which version of Microk8s works for which ONAP release. Successfuly Successfully tested is Microk8s 1.15 for Frankfurt release. E.g. the latest Microk8s version doesnt doesn't work for Frankfurt. Run the following command to install a specific version of Microk8s.
...
Code Block | ||||
---|---|---|---|---|
| ||||
microk8s enable storage
microk8s enable dns
|
Microk8s 1.15 comes with helm v2.14.3, ONAP Frankfurt release requires helm v2.16.6, you can use snap to install required helm version:
Code Block | ||||
---|---|---|---|---|
| ||||
snap install microk8shelm enable dns |
...
--classic --channel=2.16/stable
|
The default storage class is required in the Helm deploy command later on, therefore take note of it with the following command.
Code Block | ||||
---|---|---|---|---|
| ||||
microk8s kubectl get sc --all-namespaces |
Example output:
Code Block | ||||
---|---|---|---|---|
| ||||
NAME PROVISIONER AGE
microk8s-hostpath (default) microk8s.io/hostpath 29s
|
ONAP Helm charts
Clone ONAP Helm charts for specific release including submodules
git clone --branch frankfurt --recurse-submodules "https://gerrit.onap.org/r/oom"
Change to kubernetes dir
cd oom/kubernetes
Initialize Helm and configure Tiller
Code Block language bash title Configure Tiller microk8s kubectl -n kube-system create serviceaccount tiller microk8s kubectl create clusterrolebinding tiller-cluster-rule --clusterrole=cluster-admin --serviceaccount=kube-system:tiller
...
helm init --service-account tiller microk8s kubectl -n kube-system rollout status deploy/tiller-deploy
Start Helm service and initialize local Helm repository
make repo
# This will do same as:helm serve &
helm repo add local http://127.0.0.1:8879Package ONAP Helm charts
make
Deploy CDS
Run the following Helm command on oom/kubernetes directory do deploy CDS. Note that '--set global.masterPassword=random' is required for Frankfurt and probably newer releases. Storage class needs to be storage class the one from the section of Microk8s setup.
Code Block | ||||
---|---|---|---|---|
| ||||
microk8s helm upgrade --install dev ./onap --namespace onap \
--set cds.enabled=true \
--set mariadb-galera.enabled=true \
--set global.masterPassword=random \
--set cds.cds-blueprints-processor.dmaapEnabled=false \
--set global.persistence.storageClass=microk8s-hostpath
|
...
As end result you should see CDS pods running. Note that "cds-sdc-listener" POD will never get up with this setup because it's dependent on SDC.
Code Block |
---|
$ microk8s kubectl -n onap get pod
NAME READY STATUS RESTARTS AGE
dev-cds-blueprints-processor-5d74bff479-kn4jw 1/1 Running 0 8m51s
dev-cds-command-executor-745869c5f7-pt8sj 1/1 Running 0 8m51s
dev-cds-db-0 1/1 Running 0 8m51s
dev-cds-py-executor-7c5458f747-t88ws 1/1 Running 0 8m51s
dev-cds-sdc-listener-b5f59bdf5-ztsjc 0/1 Init:0/1 0 8m51s
dev-cds-ui-679cbf49fd-hswkd 1/1 Running 0 8m51s
dev-mariadb-galera-0 1/1 Running 0 8m51s
dev-mariadb-galera-1 1/1 Running 1 4m25s
dev-mariadb-galera-2 1/1 Running 0 2m36s
|
...
Ports can be forwarded e.g. to access the CDS-UI from another machine. To forward the CDS-UI Port use the following command.
Code Block |
---|
microk8s kubectl port-forward dev-cds-ui-679cbf49fd-hswkd -n onap --address 0.0.0.0 3000:3000 |
Take care to provide the right pod name and port number. The port of CDS-UI can be displayed by:
Code Block |
---|
microk8s kubectl -n onap get pod dev-cds-ui-679cbf49fd-hswkd --template='{{(index (index .spec.containers 0).ports 0).containerPort}}{{"\n"}}' |
Afterwards the CDS-UI should be accessable accessible externally.