Update Nova DB-Init jobs to match other services

This commit updates the Nova DB init jobs to match those of other
OpenStack Helm Services, it completes the work to move away from
Ansible for DB management.

Change-Id: I2e53846f917a56448392cfebe5d8548f96e3eed2
This commit is contained in:
Pete Birley 2017-04-11 15:47:12 -05:00
parent 9979444a6a
commit 93e3297a2f
5 changed files with 86 additions and 76 deletions

View File

@ -1,59 +0,0 @@
#!/bin/bash
# Copyright 2017 The Openstack-Helm Authors.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
set -ex
export HOME=/tmp
# standard database
ansible localhost -vvv \
-m mysql_db -a "login_host='{{ .Values.endpoints.oslo_db.hosts.internal | default .Values.endpoints.oslo_db.hosts.default }}' \
login_port='{{ .Values.endpoints.oslo_db.port.mysql }}' \
login_user='{{ .Values.endpoints.oslo_db.auth.admin.username }}' \
login_password='{{ .Values.endpoints.oslo_db.auth.admin.password }}' \
name='{{ .Values.endpoints.oslo_db.path | trimAll "/" }}'"
ansible localhost -vvv \
-m mysql_user -a "login_host='{{ .Values.endpoints.oslo_db.hosts.internal | default .Values.endpoints.oslo_db.hosts.default }}' \
login_port='{{ .Values.endpoints.oslo_db.port.mysql }}' \
login_user='{{ .Values.endpoints.oslo_db.auth.admin.username }}' \
login_password='{{ .Values.endpoints.oslo_db.auth.admin.password }}' \
name='{{ .Values.endpoints.oslo_db.auth.user.username }}' \
password='{{ .Values.endpoints.oslo_db.auth.user.password }}' \
host='%' \
priv='{{ .Values.endpoints.oslo_db.path | trimAll "/" }}.*:ALL' \
append_privs='yes'"
# api database
ansible localhost -vvv \
-m mysql_db -a "login_host='{{ .Values.endpoints.oslo_db_api.hosts.internal | default .Values.endpoints.oslo_db_api.hosts.default }}' \
login_port='{{ .Values.endpoints.oslo_db_api.port.mysql }}' \
login_user='{{ .Values.endpoints.oslo_db_api.auth.admin.username }}' \
login_password='{{ .Values.endpoints.oslo_db_api.auth.admin.password }}' \
name='{{ .Values.endpoints.oslo_db_api.path | trimAll "/" }}'"
ansible localhost -vvv \
-m mysql_user -a "login_host='{{ .Values.endpoints.oslo_db_api.hosts.internal | default .Values.endpoints.oslo_db_api.hosts.default }}' \
login_port='{{ .Values.endpoints.oslo_db_api.port.mysql }}' \
login_user='{{ .Values.endpoints.oslo_db_api.auth.admin.username }}' \
login_password='{{ .Values.endpoints.oslo_db_api.auth.admin.password }}' \
name='{{ .Values.endpoints.oslo_db_api.auth.user.username }}' \
password='{{ .Values.endpoints.oslo_db_api.auth.user.password }}' \
host='%' \
priv='{{ .Values.endpoints.oslo_db_api.path | trimAll "/" }}.*:ALL' \
append_privs='yes'"

View File

@ -17,7 +17,9 @@ kind: ConfigMap
metadata: metadata:
name: nova-bin name: nova-bin
data: data:
db-sync.sh: | db-init.py: |+
{{- include "helm-toolkit.db_init" . | indent 4 }}
db-sync.sh: |+
{{ tuple "bin/_db-sync.sh.tpl" . | include "helm-toolkit.template" | indent 4 }} {{ tuple "bin/_db-sync.sh.tpl" . | include "helm-toolkit.template" | indent 4 }}
ks-service.sh: |+ ks-service.sh: |+
{{- include "helm-toolkit.keystone_service" . | indent 4 }} {{- include "helm-toolkit.keystone_service" . | indent 4 }}
@ -25,8 +27,6 @@ data:
{{- include "helm-toolkit.keystone_endpoints" . | indent 4 }} {{- include "helm-toolkit.keystone_endpoints" . | indent 4 }}
ks-user.sh: |+ ks-user.sh: |+
{{- include "helm-toolkit.keystone_user" . | indent 4 }} {{- include "helm-toolkit.keystone_user" . | indent 4 }}
init.sh: |
{{ tuple "bin/_init.sh.tpl" . | include "helm-toolkit.template" | indent 4 }}
libvirt.sh: | libvirt.sh: |
{{ tuple "bin/_libvirt.sh.tpl" . | include "helm-toolkit.template" | indent 4 }} {{ tuple "bin/_libvirt.sh.tpl" . | include "helm-toolkit.template" | indent 4 }}
bootstrap.sh: | bootstrap.sh: |

View File

@ -42,14 +42,76 @@ spec:
memory: {{ .Values.resources.nova_init.limits.memory | quote }} memory: {{ .Values.resources.nova_init.limits.memory | quote }}
cpu: {{ .Values.resources.nova_init.limits.cpu | quote }} cpu: {{ .Values.resources.nova_init.limits.cpu | quote }}
{{- end }} {{- end }}
env:
- name: ROOT_DB_CONNECTION
valueFrom:
secretKeyRef:
name: nova-db-root
key: DB_CONNECTION
- name: OPENSTACK_CONFIG_FILE
value: /etc/nova/nova.conf
- name: OPENSTACK_CONFIG_DB_SECTION
value: database
- name: OPENSTACK_CONFIG_DB_KEY
value: connection
command: command:
- bash - python
- /tmp/init.sh - /tmp/db-init.py
volumeMounts: volumeMounts:
- name: nova-bin - name: nova-bin
mountPath: /tmp/init.sh mountPath: /tmp/db-init.py
subPath: init.sh subPath: db-init.py
readOnly: true
- name: etcnova
mountPath: /etc/nova
- name: novaconf
mountPath: /etc/nova/nova.conf
subPath: nova.conf
readOnly: true
- name: nova-db-init-api
image: {{ .Values.images.db_init }}
imagePullPolicy: {{ .Values.images.pull_policy }}
{{- if .Values.resources.enabled }}
resources:
requests:
memory: {{ .Values.resources.nova_init.requests.memory | quote }}
cpu: {{ .Values.resources.nova_init.requests.cpu | quote }}
limits:
memory: {{ .Values.resources.nova_init.limits.memory | quote }}
cpu: {{ .Values.resources.nova_init.limits.cpu | quote }}
{{- end }}
env:
- name: ROOT_DB_CONNECTION
valueFrom:
secretKeyRef:
name: nova-db-root
key: DB_CONNECTION
- name: OPENSTACK_CONFIG_FILE
value: /etc/nova/nova.conf
- name: OPENSTACK_CONFIG_DB_SECTION
value: api_database
- name: OPENSTACK_CONFIG_DB_KEY
value: connection
command:
- python
- /tmp/db-init.py
volumeMounts:
- name: nova-bin
mountPath: /tmp/db-init.py
subPath: db-init.py
readOnly: true
- name: etcnova
mountPath: /etc/nova
- name: novaconf
mountPath: /etc/nova/nova.conf
subPath: nova.conf
readOnly: true
volumes: volumes:
- name: etcnova
emptyDir: {}
- name: novaconf
configMap:
name: nova-etc
- name: nova-bin - name: nova-bin
configMap: configMap:
name: nova-bin name: nova-bin

View File

@ -0,0 +1,7 @@
apiVersion: v1
kind: Secret
metadata:
name: nova-db-root
type: Opaque
data:
DB_CONNECTION: {{ tuple "oslo_db" "internal" "admin" "mysql" . | include "helm-toolkit.authenticated_endpoint_uri_lookup" | b64enc }}

View File

@ -23,7 +23,7 @@ labels:
node_selector_key: openstack-compute-node node_selector_key: openstack-compute-node
node_selector_value: enabled node_selector_value: enabled
libvirt: libvirt:
node_selector_key: openstack-compute-node node_selector_key: openstack-compute-node
node_selector_value: enabled node_selector_value: enabled
conductor: conductor:
node_selector_key: openstack-control-plane node_selector_key: openstack-control-plane
@ -43,7 +43,7 @@ labels:
job: job:
node_selector_key: openstack-control-plane node_selector_key: openstack-control-plane
node_selector_value: enabled node_selector_value: enabled
replicas: replicas:
api_metadata: 1 api_metadata: 1
osapi: 1 osapi: 1
@ -52,7 +52,7 @@ replicas:
scheduler: 1 scheduler: 1
images: images:
db_init: quay.io/stackanetes/stackanetes-kolla-toolbox:newton db_init: quay.io/stackanetes/stackanetes-nova-api:newton
db_sync: quay.io/stackanetes/stackanetes-nova-api:newton db_sync: quay.io/stackanetes/stackanetes-nova-api:newton
ks_user: quay.io/stackanetes/stackanetes-kolla-toolbox:newton ks_user: quay.io/stackanetes/stackanetes-kolla-toolbox:newton
ks_service: quay.io/stackanetes/stackanetes-kolla-toolbox:newton ks_service: quay.io/stackanetes/stackanetes-kolla-toolbox:newton
@ -252,7 +252,7 @@ conf:
vncserver_listen: 0.0.0.0 vncserver_listen: 0.0.0.0
vncserver_proxyclient_address: 0.0.0.0 vncserver_proxyclient_address: 0.0.0.0
# FIXME(ALANMEADOWS) # FIXME(ALANMEADOWS)
novncproxy_base_url: http://0.0.0.0:6080/no_vnc.html novncproxy_base_url: http://0.0.0.0:6080/no_vnc.html
conductor: conductor:
nova: nova:
conf: conf:
@ -286,7 +286,7 @@ conf:
project_domain_name: default project_domain_name: default
user_domain_name: default user_domain_name: default
username: neutron username: neutron
password: password password: password
database: database:
oslo: oslo:
db: db:
@ -294,7 +294,7 @@ conf:
api_database: api_database:
oslo: oslo:
db: db:
max_retries: -1 max_retries: -1
keystone_authtoken: keystone_authtoken:
keystonemiddleware: keystonemiddleware:
auth_token: auth_token:
@ -306,7 +306,7 @@ conf:
user_domain_name: default user_domain_name: default
username: nova username: nova
password: password password: password
libvirt: libvirt:
nova: nova:
conf: conf:
@ -364,7 +364,7 @@ endpoints:
path: /nova_api path: /nova_api
scheme: mysql+pymysql scheme: mysql+pymysql
port: port:
mysql: 3306 mysql: 3306
oslo_messaging: oslo_messaging:
auth: auth:
admin: admin:
@ -378,12 +378,12 @@ endpoints:
path: / path: /
scheme: rabbit scheme: rabbit
port: port:
amqp: 5672 amqp: 5672
oslo_cache: oslo_cache:
hosts: hosts:
default: memcache default: memcache
port: port:
memcache: 11211 memcache: 11211
compute: compute:
name: nova name: nova
hosts: hosts: