Add Ceph cluster health validation on upgrade
This will prevent the Ceph Mon upgrade script from starting if the Ceph cluster is in error state. It also adds a parameter to ignore warning states, useful when performing an upgrade of a cluster where the number of healthy OSDs does not guarantee the desired replica size. Closes-Bug: 1618533 Change-Id: I1beb8ad0812f19b1018ba19b5a9fc85fa132d7f7
This commit is contained in:
parent
e5a627e43a
commit
4ea34edb79
@ -17,6 +17,21 @@ if ! [[ "$INSTALLED_VERSION" =~ ^0\.94.* ]]; then
|
|||||||
exit 0
|
exit 0
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
CEPH_STATUS=$(ceph health | awk '{print $1}')
|
||||||
|
if [ ${CEPH_STATUS} = HEALTH_ERR ]; do
|
||||||
|
echo ERROR: Ceph cluster status is HEALTH_ERR, cannot be upgraded
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Useful when upgrading with OSDs num < replica size
|
||||||
|
if [ $ignore_ceph_upgrade_warnings != "true" ]; then
|
||||||
|
timeout 300 bash -c "while [ ${CEPH_STATUS} != HEALTH_OK ]; do
|
||||||
|
echo WARNING: Waiting for Ceph cluster status to go HEALTH_OK;
|
||||||
|
sleep 30;
|
||||||
|
CEPH_STATUS=$(ceph health | awk '{print $1}')
|
||||||
|
done"
|
||||||
|
fi
|
||||||
|
|
||||||
MON_PID=$(pidof ceph-mon)
|
MON_PID=$(pidof ceph-mon)
|
||||||
MON_ID=$(hostname -s)
|
MON_ID=$(hostname -s)
|
||||||
|
|
||||||
@ -37,8 +52,6 @@ if [[ "$UPDATED_VERSION" =~ ^0\.94.* ]]; then
|
|||||||
echo WARNING: Ceph was not upgraded, restarting daemons
|
echo WARNING: Ceph was not upgraded, restarting daemons
|
||||||
service ceph start mon.${MON_ID}
|
service ceph start mon.${MON_ID}
|
||||||
elif [[ "$UPDATED_VERSION" =~ ^10\.2.* ]]; then
|
elif [[ "$UPDATED_VERSION" =~ ^10\.2.* ]]; then
|
||||||
echo INFO: Ceph was upgraded to Jewel
|
|
||||||
|
|
||||||
# RPM could own some of these but we can't take risks on the pre-existing files
|
# RPM could own some of these but we can't take risks on the pre-existing files
|
||||||
for d in /var/lib/ceph/mon /var/log/ceph /var/run/ceph /etc/ceph; do
|
for d in /var/lib/ceph/mon /var/log/ceph /var/run/ceph /etc/ceph; do
|
||||||
chown -R ceph:ceph $d
|
chown -R ceph:ceph $d
|
||||||
@ -54,9 +67,11 @@ elif [[ "$UPDATED_VERSION" =~ ^10\.2.* ]]; then
|
|||||||
|
|
||||||
# Wait for daemon to be back in the quorum
|
# Wait for daemon to be back in the quorum
|
||||||
timeout 300 bash -c "until (ceph quorum_status | jq .quorum_names | grep -sq ${MON_ID}); do
|
timeout 300 bash -c "until (ceph quorum_status | jq .quorum_names | grep -sq ${MON_ID}); do
|
||||||
echo Waiting for mon.${MON_ID} to re-join quorum;
|
echo WARNING: Waiting for mon.${MON_ID} to re-join quorum;
|
||||||
sleep 10;
|
sleep 10;
|
||||||
done"
|
done"
|
||||||
|
|
||||||
|
echo INFO: Ceph was upgraded to Jewel
|
||||||
else
|
else
|
||||||
echo ERROR: Ceph was upgraded to an unknown release, daemon is stopped, need manual intervention
|
echo ERROR: Ceph was upgraded to an unknown release, daemon is stopped, need manual intervention
|
||||||
exit 1
|
exit 1
|
||||||
|
@ -26,6 +26,10 @@ parameters:
|
|||||||
constraints:
|
constraints:
|
||||||
- allowed_values: ['auto', 'yes', 'no']
|
- allowed_values: ['auto', 'yes', 'no']
|
||||||
default: 'auto'
|
default: 'auto'
|
||||||
|
IgnoreCephUpgradeWarnings:
|
||||||
|
type: boolean
|
||||||
|
default: false
|
||||||
|
description: If enabled, Ceph upgrade will be forced even though cluster or PGs status is not clean
|
||||||
|
|
||||||
resources:
|
resources:
|
||||||
# TODO(jistr): for Mitaka->Newton upgrades and further we can use
|
# TODO(jistr): for Mitaka->Newton upgrades and further we can use
|
||||||
@ -36,7 +40,16 @@ resources:
|
|||||||
type: OS::Heat::SoftwareConfig
|
type: OS::Heat::SoftwareConfig
|
||||||
properties:
|
properties:
|
||||||
group: script
|
group: script
|
||||||
config: {get_file: major_upgrade_ceph_mon.sh}
|
config:
|
||||||
|
list_join:
|
||||||
|
- ''
|
||||||
|
- - str_replace:
|
||||||
|
template: |
|
||||||
|
#!/bin/bash
|
||||||
|
ignore_ceph_upgrade_warnings='IGNORE_CEPH_UPGRADE_WARNINGS'
|
||||||
|
params:
|
||||||
|
IGNORE_CEPH_UPGRADE_WARNINGS: {get_param: IgnoreCephUpgradeWarnings}
|
||||||
|
- get_file: major_upgrade_ceph_mon.sh
|
||||||
|
|
||||||
CephMonUpgradeDeployment:
|
CephMonUpgradeDeployment:
|
||||||
type: OS::Heat::SoftwareDeploymentGroup
|
type: OS::Heat::SoftwareDeploymentGroup
|
||||||
|
Loading…
Reference in New Issue
Block a user