Add pre-check of storage locations

Since we are about to use wildcards in storage locations,
it is possible to have multiple matches, so we need to add
precheck before using $STORAGE_LOCATION, $BLOCK_DB and $BLOCK_WAL
variables to ensure that stored strings resolve to just one and
only block location.

Signed-off-by: Ruslan Aliev <raliev@mirantis.com>
Change-Id: I60180f988e90473e200e886b69788cc263359ad2
This commit is contained in:
Ruslan Aliev 2022-03-24 21:48:19 +00:00
parent b5c285ae98
commit 109c629838
8 changed files with 59 additions and 1 deletions

View File

@ -15,6 +15,6 @@ apiVersion: v1
appVersion: v1.0.0
description: OpenStack-Helm Ceph OSD
name: ceph-osd
version: 0.1.35
version: 0.1.36
home: https://github.com/ceph/ceph
...

View File

@ -16,6 +16,8 @@ limitations under the License.
set -ex
source /tmp/utils-resolveLocations.sh
if [ "x${STORAGE_TYPE%-*}" == "xblock" ]; then
OSD_DEVICE=$(readlink -f ${STORAGE_LOCATION})
OSD_JOURNAL=$(readlink -f ${JOURNAL_LOCATION})

View File

@ -20,6 +20,8 @@ export lock_fd=''
export ALREADY_LOCKED=0
export PS4='+${BASH_SOURCE:+$(basename ${BASH_SOURCE}):${LINENO}:}${FUNCNAME:+${FUNCNAME}():} '
source /tmp/utils-resolveLocations.sh
: "${CRUSH_LOCATION:=root=default host=${HOSTNAME}}"
: "${OSD_PATH_BASE:=/var/lib/ceph/osd/${CLUSTER}}"
: "${CEPH_CONF:="/etc/ceph/${CLUSTER}.conf"}"

View File

@ -16,6 +16,8 @@ limitations under the License.
set -ex
source /tmp/utils-resolveLocations.sh
if [ "x${STORAGE_TYPE%-*}" == "xblock" ]; then
OSD_DEVICE=$(readlink -f ${STORAGE_LOCATION})
ODEV=$(echo ${OSD_DEVICE} | sed 's/[0-9]//g' | cut -f 3 -d '/')

View File

@ -0,0 +1,41 @@
#!/bin/bash
{{/*
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
if [[ "${STORAGE_LOCATION}" ]]; then
STORAGE_LOCATION=$(ls ${STORAGE_LOCATION})
if [[ `echo "${STORAGE_LOCATION}" | wc -w` -ge 2 ]]; then
echo "ERROR- Multiple locations found: ${STORAGE_LOCATION}"
exit 1
fi
fi
if [[ "${BLOCK_DB}" ]]; then
BLOCK_DB=$(ls ${BLOCK_DB})
if [[ `echo "${BLOCK_DB}" | wc -w` -ge 2 ]]; then
echo "ERROR- Multiple locations found: ${BLOCK_DB}"
exit 1
fi
fi
if [[ "${BLOCK_WAL}" ]]; then
BLOCK_WAL=$(ls ${BLOCK_WAL})
if [[ `echo "${BLOCK_WAL}" | wc -w` -ge 2 ]]; then
echo "ERROR- Multiple locations found: ${BLOCK_WAL}"
exit 1
fi
fi

View File

@ -64,4 +64,6 @@ data:
{{ tuple "bin/utils/_checkDNS.sh.tpl" . | include "helm-toolkit.utils.template" | indent 4 }}
utils-defragOSDs.sh: |
{{ tuple "bin/utils/_defragOSDs.sh.tpl" . | include "helm-toolkit.utils.template" | indent 4 }}
utils-resolveLocations.sh: |
{{ tuple "bin/utils/_resolveLocations.sh.tpl" . | include "helm-toolkit.utils.template" | indent 4 }}
{{- end }}

View File

@ -240,6 +240,10 @@ spec:
mountPath: /tmp/osd-common-ceph-volume.sh
subPath: osd-common-ceph-volume.sh
readOnly: true
- name: ceph-osd-bin
mountPath: /tmp/utils-resolveLocations.sh
subPath: utils-resolveLocations.sh
readOnly: true
- name: ceph-osd-etc
mountPath: /etc/ceph/ceph.conf.template
subPath: ceph.conf
@ -403,6 +407,10 @@ spec:
mountPath: /tmp/osd-common-ceph-volume.sh
subPath: osd-common-ceph-volume.sh
readOnly: true
- name: ceph-osd-bin
mountPath: /tmp/utils-resolveLocations.sh
subPath: utils-resolveLocations.sh
readOnly: true
- name: ceph-osd-bin
mountPath: /tmp/utils-defragOSDs.sh
subPath: utils-defragOSDs.sh

View File

@ -36,4 +36,5 @@ ceph-osd:
- 0.1.33 Update log-runner container for MAC
- 0.1.34 Remove wait for misplaced objects during OSD restarts
- 0.1.35 Consolidate mon_endpoints discovery
- 0.1.36 Add OSD device location pre-check
...