From 25a988b9c4146485cc77e1d72f89086a4d4aafeb Mon Sep 17 00:00:00 2001 From: Chris Holcombe Date: Thu, 14 Jul 2016 14:07:01 -0700 Subject: [PATCH] Fix OSD replacement Use the osd-upgrade key when replacing OSD's as this key has the correct cephx permissions to perform the operation. Closes-Bug: 1602826 Depends-On: I6af43b61149c6eeeeb5c77950701194beda2da71 Change-Id: I32d2f1a4036e09d5d1fd13009c95ab1514e7304c --- hooks/ceph.py | 32 ++++++++++++++++++++++++-------- unit_tests/test_replace_osd.py | 15 +++++++++++---- 2 files changed, 35 insertions(+), 12 deletions(-) diff --git a/hooks/ceph.py b/hooks/ceph.py index 22e6c9af..09f70960 100644 --- a/hooks/ceph.py +++ b/hooks/ceph.py @@ -362,8 +362,12 @@ def replace_osd(dead_osd_number, # Drop this osd out of the cluster. This will begin a # rebalance operation status_set('maintenance', 'Removing osd {}'.format(dead_osd_number)) - subprocess.check_output(['ceph', 'osd', 'out', - 'osd.{}'.format(dead_osd_number)]) + subprocess.check_output([ + 'ceph', + '--id', + 'osd-upgrade', + 'osd', 'out', + 'osd.{}'.format(dead_osd_number)]) # Kill the osd process if it's not already dead if systemd(): @@ -378,13 +382,25 @@ def replace_osd(dead_osd_number, mount_point, os.strerror(ret))) # Clean up the old mount point shutil.rmtree(mount_point) - subprocess.check_output(['ceph', 'osd', 'crush', 'remove', - 'osd.{}'.format(dead_osd_number)]) + subprocess.check_output([ + 'ceph', + '--id', + 'osd-upgrade', + 'osd', 'crush', 'remove', + 'osd.{}'.format(dead_osd_number)]) # Revoke the OSDs access keys - subprocess.check_output(['ceph', 'auth', 'del', - 'osd.{}'.format(dead_osd_number)]) - subprocess.check_output(['ceph', 'osd', 'rm', - 'osd.{}'.format(dead_osd_number)]) + subprocess.check_output([ + 'ceph', + '--id', + 'osd-upgrade', + 'auth', 'del', + 'osd.{}'.format(dead_osd_number)]) + subprocess.check_output([ + 'ceph', + '--id', + 'osd-upgrade', + 'osd', 'rm', + 'osd.{}'.format(dead_osd_number)]) status_set('maintenance', 'Setting up replacement osd {}'.format( new_osd_device)) osdize(new_osd_device, diff --git a/unit_tests/test_replace_osd.py b/unit_tests/test_replace_osd.py index dd3e9c11..ce919382 100644 --- a/unit_tests/test_replace_osd.py +++ b/unit_tests/test_replace_osd.py @@ -79,13 +79,16 @@ class ReplaceOsdTestCase(test_utils.CharmTestCase): @patch('ceph.osdize') @patch('ceph.shutil') @patch('ceph.systemd') + @patch('ceph.ceph_user') def test_replace_osd(self, + ceph_user, systemd, shutil, osdize, umount, subprocess, mounts): + ceph_user.return_value = "ceph" mounts.return_value = [['/var/lib/ceph/osd/ceph-a', '/dev/sda']] subprocess.check_output.return_value = True self.status_set.return_value = None @@ -102,11 +105,15 @@ class ReplaceOsdTestCase(test_utils.CharmTestCase): ignore_errors=False) subprocess.check_output.assert_has_calls( [ - call(['ceph', 'osd', 'out', 'osd.0']), + call(['ceph', '--id', 'osd-upgrade', + 'osd', 'out', 'osd.0']), call(['stop', 'ceph-osd', 'id=0']), - call(['ceph', 'osd', 'crush', 'remove', 'osd.0']), - call(['ceph', 'auth', 'del', 'osd.0']), - call(['ceph', 'osd', 'rm', 'osd.0']) + call(['ceph', '--id', + 'osd-upgrade', 'osd', 'crush', 'remove', 'osd.0']), + call(['ceph', '--id', + 'osd-upgrade', 'auth', 'del', 'osd.0']), + call(['ceph', '--id', + 'osd-upgrade', 'osd', 'rm', 'osd.0']) ] )