charts: add supprot to pull images from private registry
[pti/o2.git] / README-o2imsbuilder.md
1
2 ## Build and deploy O2 services over O-Cloud (INF)
3
4
5 ## Bring up builder container from O-Cloud controller node
6
7
8 ```sh
9 mkdir -p /home/sysadmin/share
10 sudo docker run -dt --privileged -v /home/sysadmin/share/:/home/sysadmin/share/ -v /var/run:/var/run --name o2imsbuilder centos:7
11 ```
12
13 ## Build O2 service images inside the builder container
14
15
16 ```sh
17 sudo docker exec -it o2imsbuilder bash
18 ```
19
20
21 ```sh
22 curl -L https://get.daocloud.io/docker/compose/releases/download/1.25.4/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose
23 chmod +x /usr/local/bin/docker-compose
24 docker-compose -v
25
26 yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
27 yum makecache fast
28 yum install -y docker-ce
29 docker ps
30
31 yum install -y git
32
33 cd /home/sysadmin/share/
34 git clone "https://gerrit.o-ran-sc.org/r/pti/o2"
35 cd o2
36
37 mkdir -p temp
38 cd temp
39 git clone --depth 1 --branch master https://opendev.org/starlingx/config.git
40 git clone --depth 1 --branch master https://opendev.org/starlingx/distcloud-client.git
41 cd -
42
43 docker-compose build
44
45 exit
46
47 ```
48
49 ### Push O2 service images to local registry (with auth user admin)
50
51 ```sh
52 sudo docker tag o2imsdms:latest registry.local:9001/o-ran-sc/pti-o2imsdms:2.0.0
53 sudo docker image push registry.local:9001/o-ran-sc/pti-o2imsdms:2.0.0
54
55 ```
56
57 ## Deploy O2 services with helm chart over O-Cloud controller node (with auth user admin)
58
59 ```sh
60 export NAMESPACE=oran-o2
61 kubectl create ns ${NAMESPACE}
62
63 cd /home/sysadmin/
64 source /etc/platform/openrc
65 cat <<EOF>ocloud-override.yaml
66 imagePullSecrets:
67   - default-registry-key
68
69 o2ims:
70   serviceaccountname: admin-oran-o2
71   image:
72     img_o2: registry.local:9001/o-ran-sc/pti-o2imsdms:2.0.0
73     img_postgres: postgres:9.6
74     img_redis: redis:alpine
75     pullPolicy: IfNotPresent
76   logginglevel: "DEBUG"
77
78 ocloud:
79   OS_AUTH_URL: "${OS_AUTH_URL}"
80   OS_USERNAME: "${OS_USERNAME}"
81   OS_PASSWORD: "${OS_PASSWORD}"
82 EOF
83
84 sudo docker login registry.local:9001 -u ${OS_PROJECT_NAME} -p ${OS_PASSWORD}
85
86 kubectl -n ${NAMESPACE} create secret docker-registry ${OS_PROJECT_NAME}-${NAMESPACE}-registry-secret \
87 --docker-server=registry.local:9001 --docker-username=${OS_PROJECT_NAME} \
88 --docker-password=${OS_PASSWORD} --docker-email=noreply@windriver.com
89
90 cd /home/sysadmin/share/o2
91
92 helm install o2imstest charts/ -f /home/sysadmin/ocloud-override.yaml
93
94 kubectl -n ${NAMESPACE} get pods
95
96 ```
97
98 ### test api endpoint
99
100 ```sh
101 curl -k http(s)://<Node IP>:30205
102 curl -k http(s)://<Node IP>:30205/o2ims_infrastructureInventory/v1
103 ```
104
105
106 ### Debug tips
107
108 ```sh
109 kubectl -n ${NAMESPACE} logs -f o2api-<xxx> -c o2api
110 kubectl -n ${NAMESPACE} logs -f o2api-<xxx> -c postgres
111 kubectl -n ${NAMESPACE} logs -f o2api-<xxx> -c o2pubsub
112 kubectl -n ${NAMESPACE} logs -f o2api-<xxx> -c watcher
113
114
115 kubectl -n ${NAMESPACE} logs -f o2api-<xxx> -c o2api
116
117 kubectl -n ${NAMESPACE} exec -it o2api-<xxx> -c postgres -- bash
118     psql -U o2ims
119
120         \c o2ims
121
122         \d
123
124         select * from ocloud;
125
126         \q
127
128     exit
129
130 ```
131
132 ## Issues:
133
134 1, there is chance the containers crash due to random bootstrap order of containers