Merge "Nova: Update cell and db management"
This commit is contained in:
commit
de72d74ae6
@ -18,4 +18,11 @@ limitations under the License.
|
|||||||
|
|
||||||
set -ex
|
set -ex
|
||||||
|
|
||||||
nova-manage cell_v2 simple_cell_setup
|
NOVA_VERSION=$(nova-manage --version 2>&1 > /dev/null)
|
||||||
|
|
||||||
|
# NOTE(portdirect): check if nova fully supports cells v2, and manage
|
||||||
|
# accordingly. Support was complete in ocata (V14.x.x).
|
||||||
|
|
||||||
|
if [ "${NOVA_VERSION%%.*}" -gt "14" ]; then
|
||||||
|
nova-manage cell_v2 discover_hosts --verbose
|
||||||
|
fi
|
||||||
|
@ -18,6 +18,30 @@ limitations under the License.
|
|||||||
|
|
||||||
set -ex
|
set -ex
|
||||||
|
|
||||||
nova-manage db sync
|
NOVA_VERSION=$(nova-manage --version 2>&1 > /dev/null)
|
||||||
|
|
||||||
|
function manage_cells () {
|
||||||
|
# NOTE(portdirect): check if nova fully supports cells v2, and manage
|
||||||
|
# accordingly. Support was complete in ocata (V14.x.x).
|
||||||
|
if [ "${NOVA_VERSION%%.*}" -gt "14" ]; then
|
||||||
|
nova-manage cell_v2 map_cell0
|
||||||
|
nova-manage cell_v2 list_cells | grep -q " cell1 " || \
|
||||||
|
nova-manage cell_v2 create_cell --name=cell1 --verbose
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# NOTE(portdirect): if the db has been populated we should setup cells if
|
||||||
|
# required, otherwise we should poulate the api db, and then setup cells.
|
||||||
|
if [ "$(nova-manage api_db version)" -gt "0" ]; then
|
||||||
|
manage_cells
|
||||||
nova-manage api_db sync
|
nova-manage api_db sync
|
||||||
|
else
|
||||||
|
nova-manage api_db sync
|
||||||
|
manage_cells
|
||||||
|
fi
|
||||||
|
|
||||||
|
nova-manage db sync
|
||||||
|
|
||||||
nova-manage db online_data_migrations
|
nova-manage db online_data_migrations
|
||||||
|
|
||||||
|
echo 'Finished DB migrations'
|
||||||
|
82
nova/templates/cron-job-cell-setup.yaml
Normal file
82
nova/templates/cron-job-cell-setup.yaml
Normal file
@ -0,0 +1,82 @@
|
|||||||
|
{{/*
|
||||||
|
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.
|
||||||
|
*/}}
|
||||||
|
|
||||||
|
{{- if .Values.manifests.cron_job_cell_setup }}
|
||||||
|
{{- $envAll := . }}
|
||||||
|
{{- $dependencies := .Values.dependencies.static.cell_setup }}
|
||||||
|
|
||||||
|
{{- $serviceAccountName := "nova-cell-setup" }}
|
||||||
|
{{ tuple $envAll $dependencies $serviceAccountName | include "helm-toolkit.snippets.kubernetes_pod_rbac_serviceaccount" }}
|
||||||
|
---
|
||||||
|
apiVersion: batch/v1beta1
|
||||||
|
kind: CronJob
|
||||||
|
metadata:
|
||||||
|
name: nova-cell-setup
|
||||||
|
spec:
|
||||||
|
schedule: {{ .Values.jobs.cell_setup.cron | quote }}
|
||||||
|
successfulJobsHistoryLimit: {{ .Values.jobs.cell_setup.history.success }}
|
||||||
|
failedJobsHistoryLimit: {{ .Values.jobs.cell_setup.history.failed }}
|
||||||
|
concurrencyPolicy: Forbid
|
||||||
|
jobTemplate:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
{{ tuple $envAll "nova" "cell-setup" | include "helm-toolkit.snippets.kubernetes_metadata_labels" | indent 8 }}
|
||||||
|
spec:
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
{{ tuple $envAll "nova" "cell-setup" | include "helm-toolkit.snippets.kubernetes_metadata_labels" | indent 12 }}
|
||||||
|
spec:
|
||||||
|
serviceAccountName: {{ $serviceAccountName }}
|
||||||
|
restartPolicy: OnFailure
|
||||||
|
nodeSelector:
|
||||||
|
{{ .Values.labels.job.node_selector_key }}: {{ .Values.labels.job.node_selector_value }}
|
||||||
|
initContainers:
|
||||||
|
{{ tuple $envAll $dependencies list | include "helm-toolkit.snippets.kubernetes_entrypoint_init_container" | indent 12 }}
|
||||||
|
containers:
|
||||||
|
- name: nova-cell-setup
|
||||||
|
image: {{ .Values.images.tags.nova_cell_setup }}
|
||||||
|
imagePullPolicy: {{ .Values.images.pull_policy }}
|
||||||
|
{{ tuple $envAll $envAll.Values.pod.resources.jobs.cell_setup | include "helm-toolkit.snippets.kubernetes_resources" | indent 14 }}
|
||||||
|
command:
|
||||||
|
- /tmp/cell-setup.sh
|
||||||
|
volumeMounts:
|
||||||
|
- name: nova-bin
|
||||||
|
mountPath: /tmp/cell-setup.sh
|
||||||
|
subPath: cell-setup.sh
|
||||||
|
readOnly: true
|
||||||
|
- name: etcnova
|
||||||
|
mountPath: /etc/nova
|
||||||
|
- name: nova-etc
|
||||||
|
mountPath: /etc/nova/nova.conf
|
||||||
|
subPath: nova.conf
|
||||||
|
readOnly: true
|
||||||
|
- name: nova-etc
|
||||||
|
mountPath: /etc/nova/policy.yaml
|
||||||
|
subPath: policy.yaml
|
||||||
|
readOnly: true
|
||||||
|
volumes:
|
||||||
|
- name: etcnova
|
||||||
|
emptyDir: {}
|
||||||
|
- name: nova-etc
|
||||||
|
configMap:
|
||||||
|
name: nova-etc
|
||||||
|
defaultMode: 0444
|
||||||
|
- name: nova-bin
|
||||||
|
configMap:
|
||||||
|
name: nova-bin
|
||||||
|
defaultMode: 0555
|
||||||
|
{{- end }}
|
@ -1,73 +0,0 @@
|
|||||||
{{/*
|
|
||||||
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.
|
|
||||||
*/}}
|
|
||||||
|
|
||||||
{{- if .Values.manifests.job_cell_setup }}
|
|
||||||
{{- $envAll := . }}
|
|
||||||
{{- $dependencies := .Values.dependencies.static.cell_setup }}
|
|
||||||
|
|
||||||
{{- $serviceAccountName := "nova-cell-setup" }}
|
|
||||||
{{ tuple $envAll $dependencies $serviceAccountName | include "helm-toolkit.snippets.kubernetes_pod_rbac_serviceaccount" }}
|
|
||||||
---
|
|
||||||
apiVersion: batch/v1
|
|
||||||
kind: Job
|
|
||||||
metadata:
|
|
||||||
name: nova-cell-setup
|
|
||||||
spec:
|
|
||||||
template:
|
|
||||||
metadata:
|
|
||||||
labels:
|
|
||||||
{{ tuple $envAll "nova" "cell-setup" | include "helm-toolkit.snippets.kubernetes_metadata_labels" | indent 8 }}
|
|
||||||
spec:
|
|
||||||
serviceAccountName: {{ $serviceAccountName }}
|
|
||||||
restartPolicy: OnFailure
|
|
||||||
nodeSelector:
|
|
||||||
{{ .Values.labels.job.node_selector_key }}: {{ .Values.labels.job.node_selector_value }}
|
|
||||||
initContainers:
|
|
||||||
{{ tuple $envAll $dependencies list | include "helm-toolkit.snippets.kubernetes_entrypoint_init_container" | indent 8 }}
|
|
||||||
containers:
|
|
||||||
- name: nova-cell-setup
|
|
||||||
image: {{ .Values.images.tags.nova_cell_setup }}
|
|
||||||
imagePullPolicy: {{ .Values.images.pull_policy }}
|
|
||||||
{{ tuple $envAll $envAll.Values.pod.resources.jobs.cell_setup | include "helm-toolkit.snippets.kubernetes_resources" | indent 10 }}
|
|
||||||
command:
|
|
||||||
- /tmp/cell-setup.sh
|
|
||||||
volumeMounts:
|
|
||||||
- name: nova-bin
|
|
||||||
mountPath: /tmp/cell-setup.sh
|
|
||||||
subPath: cell-setup.sh
|
|
||||||
readOnly: true
|
|
||||||
- name: etcnova
|
|
||||||
mountPath: /etc/nova
|
|
||||||
- name: nova-etc
|
|
||||||
mountPath: /etc/nova/nova.conf
|
|
||||||
subPath: nova.conf
|
|
||||||
readOnly: true
|
|
||||||
- name: nova-etc
|
|
||||||
mountPath: /etc/nova/policy.yaml
|
|
||||||
subPath: policy.yaml
|
|
||||||
readOnly: true
|
|
||||||
volumes:
|
|
||||||
- name: etcnova
|
|
||||||
emptyDir: {}
|
|
||||||
- name: nova-etc
|
|
||||||
configMap:
|
|
||||||
name: nova-etc
|
|
||||||
defaultMode: 0444
|
|
||||||
- name: nova-bin
|
|
||||||
configMap:
|
|
||||||
name: nova-bin
|
|
||||||
defaultMode: 0555
|
|
||||||
{{- end }}
|
|
@ -85,6 +85,15 @@ images:
|
|||||||
nova_spiceproxy_assets: 'docker.io/kolla/ubuntu-source-nova-spicehtml5proxy:3.0.3'
|
nova_spiceproxy_assets: 'docker.io/kolla/ubuntu-source-nova-spicehtml5proxy:3.0.3'
|
||||||
test: 'docker.io/kolla/ubuntu-source-rally:4.0.0'
|
test: 'docker.io/kolla/ubuntu-source-rally:4.0.0'
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
# NOTE(portdirect): When using cells new nodes will be added to the cell on the hour by default.
|
||||||
|
# TODO(portdirect): Add a post-start action to nova compute pods that registers themselves.
|
||||||
|
cell_setup:
|
||||||
|
cron: "0 */1 * * *"
|
||||||
|
history:
|
||||||
|
success: 3
|
||||||
|
failed: 1
|
||||||
|
|
||||||
bootstrap:
|
bootstrap:
|
||||||
enabled: true
|
enabled: true
|
||||||
ks_user: admin
|
ks_user: admin
|
||||||
@ -252,6 +261,11 @@ dependencies:
|
|||||||
service: identity
|
service: identity
|
||||||
- endpoint: internal
|
- endpoint: internal
|
||||||
service: compute
|
service: compute
|
||||||
|
pod:
|
||||||
|
- requireSameNode: false
|
||||||
|
labels:
|
||||||
|
application: nova
|
||||||
|
component: compute
|
||||||
compute:
|
compute:
|
||||||
pod:
|
pod:
|
||||||
- requireSameNode: true
|
- requireSameNode: true
|
||||||
@ -1614,6 +1628,7 @@ pod:
|
|||||||
manifests:
|
manifests:
|
||||||
configmap_bin: true
|
configmap_bin: true
|
||||||
configmap_etc: true
|
configmap_etc: true
|
||||||
|
cron_job_cell_setup: true
|
||||||
daemonset_compute: true
|
daemonset_compute: true
|
||||||
deployment_api_metadata: true
|
deployment_api_metadata: true
|
||||||
deployment_api_osapi: true
|
deployment_api_osapi: true
|
||||||
@ -1639,7 +1654,6 @@ manifests:
|
|||||||
job_ks_placement_endpoints: true
|
job_ks_placement_endpoints: true
|
||||||
job_ks_placement_service: true
|
job_ks_placement_service: true
|
||||||
job_ks_placement_user: true
|
job_ks_placement_user: true
|
||||||
job_cell_setup: true
|
|
||||||
pdb_metadata: true
|
pdb_metadata: true
|
||||||
pdb_placement: true
|
pdb_placement: true
|
||||||
pdb_osapi: true
|
pdb_osapi: true
|
||||||
|
Loading…
Reference in New Issue
Block a user