Merge "Upgrade ceph-osd"
This commit is contained in:
commit
925f624dcc
@ -4,32 +4,89 @@
|
|||||||
# major upgrade workflow.
|
# major upgrade workflow.
|
||||||
#
|
#
|
||||||
set -eu
|
set -eu
|
||||||
|
set -o pipefail
|
||||||
|
|
||||||
UPGRADE_SCRIPT=/root/tripleo_upgrade_node.sh
|
UPGRADE_SCRIPT=/root/tripleo_upgrade_node.sh
|
||||||
|
|
||||||
cat > $UPGRADE_SCRIPT << ENDOFCAT
|
cat > $UPGRADE_SCRIPT << 'ENDOFCAT'
|
||||||
|
#!/bin/bash
|
||||||
### DO NOT MODIFY THIS FILE
|
### DO NOT MODIFY THIS FILE
|
||||||
### This file is automatically delivered to the ceph-storage nodes as part of the
|
### This file is automatically delivered to the ceph-storage nodes as part of the
|
||||||
### tripleo upgrades workflow
|
### tripleo upgrades workflow
|
||||||
|
set -eu
|
||||||
|
|
||||||
|
echo INFO: starting $(basename "$0")
|
||||||
|
|
||||||
function systemctl_ceph {
|
# Exit if not running
|
||||||
action=\$1
|
if ! pidof ceph-osd; then
|
||||||
systemctl \$action ceph
|
echo INFO: ceph-osd is not running, skipping
|
||||||
}
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
# "so that mirrors aren't rebalanced as if the OSD died" - gfidente
|
# Exit if not Hammer
|
||||||
|
INSTALLED_VERSION=$(ceph --version | awk '{print $3}')
|
||||||
|
if ! [[ "$INSTALLED_VERSION" =~ ^0\.94.* ]]; then
|
||||||
|
echo INFO: version of Ceph installed is not 0.94, skipping
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
OSD_PIDS=$(pidof ceph-osd)
|
||||||
|
OSD_IDS=$(ls /var/lib/ceph/osd | awk 'BEGIN { FS = "-" } ; { print $2 }')
|
||||||
|
|
||||||
|
# "so that mirrors aren't rebalanced as if the OSD died" - gfidente / leseb
|
||||||
ceph osd set noout
|
ceph osd set noout
|
||||||
|
ceph osd set norebalance
|
||||||
|
ceph osd set nodeep-scrub
|
||||||
|
ceph osd set noscrub
|
||||||
|
|
||||||
systemctl_ceph stop
|
# Stop daemon using Hammer sysvinit script
|
||||||
|
for OSD_ID in $OSD_IDS; do
|
||||||
|
service ceph stop osd.${OSD_ID}
|
||||||
|
done
|
||||||
|
|
||||||
|
# Nice guy will return non-0 only when all failed
|
||||||
|
timeout 60 bash -c "while kill -0 ${OSD_PIDS} 2> /dev/null; do
|
||||||
|
sleep 2;
|
||||||
|
done"
|
||||||
|
|
||||||
|
# Update (Ceph to Jewel)
|
||||||
yum -y install python-zaqarclient # needed for os-collect-config
|
yum -y install python-zaqarclient # needed for os-collect-config
|
||||||
yum -y update
|
yum -y update
|
||||||
systemctl_ceph start
|
|
||||||
|
# Restart/Exit if not on Jewel, only in that case we need the changes
|
||||||
|
UPDATED_VERSION=$(ceph --version | awk '{print $3}')
|
||||||
|
if [[ "$UPDATED_VERSION" =~ ^0\.94.* ]]; then
|
||||||
|
echo WARNING: Ceph was not upgraded, restarting daemon
|
||||||
|
for OSD_ID in $OSD_IDS; do
|
||||||
|
service ceph start osd.${OSD_ID}
|
||||||
|
done
|
||||||
|
elif [[ "$UPDATED_VERSION" =~ ^10\.2.* ]]; then
|
||||||
|
# RPM could own some of these but we can't take risks on the pre-existing files
|
||||||
|
for d in /var/lib/ceph/osd /var/log/ceph /var/run/ceph /etc/ceph; do
|
||||||
|
chown -R ceph:ceph $d
|
||||||
|
done
|
||||||
|
|
||||||
|
# Replay udev events with newer rules
|
||||||
|
udevadm trigger && udevadm settle
|
||||||
|
|
||||||
|
# Enable systemd unit
|
||||||
|
systemctl enable ceph-osd.target
|
||||||
|
for OSD_ID in $OSD_IDS; do
|
||||||
|
systemctl enable ceph-osd@${OSD_ID}
|
||||||
|
systemctl start ceph-osd@${OSD_ID}
|
||||||
|
done
|
||||||
|
|
||||||
|
echo INFO: Ceph was upgraded to Jewel
|
||||||
|
else
|
||||||
|
echo ERROR: Ceph was upgraded to an unknown release, daemon is stopped, need manual intervention
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
ceph osd unset noout
|
ceph osd unset noout
|
||||||
|
ceph osd unset norebalance
|
||||||
|
ceph osd unset nodeep-scrub
|
||||||
|
ceph osd unset noscrub
|
||||||
ENDOFCAT
|
ENDOFCAT
|
||||||
|
|
||||||
# ensure the permissions are OK
|
# ensure the permissions are OK
|
||||||
chmod 0755 $UPGRADE_SCRIPT
|
chmod 0755 $UPGRADE_SCRIPT
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user