Glance: Fix storage-init script
The new storage-init script doesn't handle the case in which the rbd pool user already exists. This PS solves the issue by improving the script. Change-Id: I22c55429d3077393b279fb784845db41a69b5469 Closes-Bug: 1719081
This commit is contained in:
parent
f5410e8bca
commit
983685837f
31
glance/templates/bin/_ceph-admin-keyring.sh.tpl
Normal file
31
glance/templates/bin/_ceph-admin-keyring.sh.tpl
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
#!/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
|
||||||
|
|
||||||
|
cat <<EOF > /etc/ceph/ceph.client.admin.keyring
|
||||||
|
[client.admin]
|
||||||
|
{{- if .Values.conf.ceph.admin_keyring }}
|
||||||
|
key = {{ .Values.conf.ceph.admin_keyring }}
|
||||||
|
{{- else }}
|
||||||
|
key = $(cat /tmp/client-keyring)
|
||||||
|
{{- end }}
|
||||||
|
EOF
|
||||||
|
|
||||||
|
exit 0
|
@ -21,11 +21,7 @@ export HOME=/tmp
|
|||||||
|
|
||||||
cat <<EOF > /etc/ceph/ceph.client.${RBD_STORE_USER}.keyring
|
cat <<EOF > /etc/ceph/ceph.client.${RBD_STORE_USER}.keyring
|
||||||
[client.${RBD_STORE_USER}]
|
[client.${RBD_STORE_USER}]
|
||||||
{{- if .Values.conf.ceph.keyring }}
|
|
||||||
key = {{ .Values.conf.ceph.keyring }}
|
|
||||||
{{- else }}
|
|
||||||
key = $(cat /tmp/client-keyring)
|
key = $(cat /tmp/client-keyring)
|
||||||
{{- end }}
|
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
exit 0
|
exit 0
|
||||||
|
@ -36,11 +36,16 @@ elif [ "x$STORAGE_BACKEND" == "xrbd" ]; then
|
|||||||
}
|
}
|
||||||
ensure_pool ${RBD_POOL_NAME} ${RBD_POOL_CHUNK_SIZE}
|
ensure_pool ${RBD_POOL_NAME} ${RBD_POOL_CHUNK_SIZE}
|
||||||
|
|
||||||
|
if USERINFO=$(ceph auth get client.${RBD_POOL_USER}); then
|
||||||
|
KEYSTR=$(echo $USERINFO | sed 's/.*\( key = .*\) caps mon.*/\1/')
|
||||||
|
echo $KEYSTR > ${KEYRING}
|
||||||
|
else
|
||||||
#NOTE(Portdirect): Determine proper privs to assign keyring
|
#NOTE(Portdirect): Determine proper privs to assign keyring
|
||||||
ceph auth get-or-create client.${RBD_POOL_USER} \
|
ceph auth get-or-create client.${RBD_POOL_USER} \
|
||||||
mon "allow *" \
|
mon "allow *" \
|
||||||
osd "allow *" \
|
osd "allow *" \
|
||||||
-o ${KEYRING}
|
-o ${KEYRING}
|
||||||
|
fi
|
||||||
|
|
||||||
ENCODED_KEYRING=$(sed -n 's/^[[:blank:]]*key[[:blank:]]\+=[[:blank:]]\(.*\)/\1/p' ${KEYRING} | base64 -w0)
|
ENCODED_KEYRING=$(sed -n 's/^[[:blank:]]*key[[:blank:]]\+=[[:blank:]]\(.*\)/\1/p' ${KEYRING} | base64 -w0)
|
||||||
cat > ${SECRET} <<EOF
|
cat > ${SECRET} <<EOF
|
||||||
|
@ -45,6 +45,8 @@ data:
|
|||||||
{{ tuple "bin/_bootstrap.sh.tpl" . | include "helm-toolkit.utils.template" | indent 4 }}
|
{{ tuple "bin/_bootstrap.sh.tpl" . | include "helm-toolkit.utils.template" | indent 4 }}
|
||||||
ceph-keyring.sh: |+
|
ceph-keyring.sh: |+
|
||||||
{{ tuple "bin/_ceph-keyring.sh.tpl" . | include "helm-toolkit.utils.template" | indent 4 }}
|
{{ tuple "bin/_ceph-keyring.sh.tpl" . | include "helm-toolkit.utils.template" | indent 4 }}
|
||||||
|
ceph-admin-keyring.sh: |+
|
||||||
|
{{ tuple "bin/_ceph-admin-keyring.sh.tpl" . | include "helm-toolkit.utils.template" | indent 4 }}
|
||||||
clean-image.sh: |+
|
clean-image.sh: |+
|
||||||
{{ tuple "bin/_clean-image.sh.tpl" . | include "helm-toolkit.utils.template" | indent 4 }}
|
{{ tuple "bin/_clean-image.sh.tpl" . | include "helm-toolkit.utils.template" | indent 4 }}
|
||||||
clean-secrets.sh: |+
|
clean-secrets.sh: |+
|
||||||
|
@ -39,17 +39,14 @@ spec:
|
|||||||
imagePullPolicy: {{ .Values.images.pull_policy }}
|
imagePullPolicy: {{ .Values.images.pull_policy }}
|
||||||
securityContext:
|
securityContext:
|
||||||
runAsUser: {{ .Values.pod.user.glance.uid }}
|
runAsUser: {{ .Values.pod.user.glance.uid }}
|
||||||
env:
|
|
||||||
- name: RBD_STORE_USER
|
|
||||||
value: admin
|
|
||||||
command:
|
command:
|
||||||
- /tmp/ceph-keyring.sh
|
- /tmp/ceph-admin-keyring.sh
|
||||||
volumeMounts:
|
volumeMounts:
|
||||||
- name: etcceph
|
- name: etcceph
|
||||||
mountPath: /etc/ceph
|
mountPath: /etc/ceph
|
||||||
- name: glance-bin
|
- name: glance-bin
|
||||||
mountPath: /tmp/ceph-keyring.sh
|
mountPath: /tmp/ceph-admin-keyring.sh
|
||||||
subPath: ceph-keyring.sh
|
subPath: ceph-admin-keyring.sh
|
||||||
readOnly: true
|
readOnly: true
|
||||||
- name: ceph-keyring
|
- name: ceph-keyring
|
||||||
mountPath: /tmp/client-keyring
|
mountPath: /tmp/client-keyring
|
||||||
|
@ -68,7 +68,7 @@ conf:
|
|||||||
container_format: bare
|
container_format: bare
|
||||||
ceph:
|
ceph:
|
||||||
monitors: []
|
monitors: []
|
||||||
keyring: null
|
admin_keyring: null
|
||||||
override:
|
override:
|
||||||
append:
|
append:
|
||||||
ceph_client:
|
ceph_client:
|
||||||
|
Loading…
Reference in New Issue
Block a user