Merge "Fix volume migration fails in the same ceph RBD pool"

This commit is contained in:
Zuul 2020-04-22 22:32:43 +00:00 committed by Gerrit Code Review
commit 5cbf91c60c
3 changed files with 55 additions and 6 deletions

View File

@ -2311,7 +2311,7 @@ class RBDTestCase(test.TestCase):
self.assertEqual(3.00, total_provision) self.assertEqual(3.00, total_provision)
def test_migrate_volume_bad_volume_status(self): def test_migrate_volume_bad_volume_status(self):
self.volume_a.status = 'in-use' self.volume_a.status = 'backuping'
ret = self.driver.migrate_volume(context, self.volume_a, None) ret = self.driver.migrate_volume(context, self.volume_a, None)
self.assertEqual((False, None), ret) self.assertEqual((False, None), ret)
@ -2373,8 +2373,7 @@ class RBDTestCase(test.TestCase):
@mock.patch('os_brick.initiator.linuxrbd.rbd') @mock.patch('os_brick.initiator.linuxrbd.rbd')
@mock.patch('os_brick.initiator.linuxrbd.RBDClient') @mock.patch('os_brick.initiator.linuxrbd.RBDClient')
@mock.patch('cinder.volume.drivers.rbd.RBDVolumeProxy') def test_migrate_volume_same_pool(self, mock_client, mock_rbd):
def test_migrate_volume(self, mock_proxy, mock_client, mock_rbd):
host = { host = {
'capabilities': { 'capabilities': {
'storage_protocol': 'ceph', 'storage_protocol': 'ceph',
@ -2382,6 +2381,39 @@ class RBDTestCase(test.TestCase):
mock_client().__enter__().client.get_fsid.return_value = 'abc' mock_client().__enter__().client.get_fsid.return_value = 'abc'
with mock.patch.object(self.driver, '_get_fsid') as mock_get_fsid:
mock_get_fsid.return_value = 'abc'
ret = self.driver.migrate_volume(context, self.volume_a, host)
self.assertEqual((True, None), ret)
@mock.patch('os_brick.initiator.linuxrbd.rbd')
@mock.patch('os_brick.initiator.linuxrbd.RBDClient')
def test_migrate_volume_insue_different_pool(self, mock_client, mock_rbd):
self.volume_a.status = 'in-use'
host = {
'capabilities': {
'storage_protocol': 'ceph',
'location_info': 'nondefault:None:abc:None:rbd2'}}
mock_client().__enter__().client.get_fsid.return_value = 'abc'
with mock.patch.object(self.driver, '_get_fsid') as mock_get_fsid:
mock_get_fsid.return_value = 'abc'
ret = self.driver.migrate_volume(context, self.volume_a, host)
self.assertEqual((False, None), ret)
@mock.patch('os_brick.initiator.linuxrbd.rbd')
@mock.patch('os_brick.initiator.linuxrbd.RBDClient')
@mock.patch('cinder.volume.drivers.rbd.RBDVolumeProxy')
def test_migrate_volume_different_pool(self, mock_proxy, mock_client,
mock_rbcd):
host = {
'capabilities': {
'storage_protocol': 'ceph',
'location_info': 'nondefault:None:abc:None:rbd2'}}
mock_client().__enter__().client.get_fsid.return_value = 'abc'
with mock.patch.object(self.driver, '_get_fsid') as mock_get_fsid, \ with mock.patch.object(self.driver, '_get_fsid') as mock_get_fsid, \
mock.patch.object(self.driver, 'delete_volume') as mock_delete: mock.patch.object(self.driver, 'delete_volume') as mock_delete:
mock_get_fsid.return_value = 'abc' mock_get_fsid.return_value = 'abc'

View File

@ -1823,9 +1823,11 @@ class RBDDriver(driver.CloneableImageVD, driver.MigrateVD,
refuse_to_migrate = (False, None) refuse_to_migrate = (False, None)
if volume.status not in ('available', 'retyping', 'maintenance'): if volume.status not in ('available', 'retyping', 'maintenance',
LOG.debug('Only available volumes can be migrated using backend ' 'in-use'):
'assisted migration. Falling back to generic migration.') LOG.debug('Only available or in-use volumes can be migrated using'
'backend assisted migration. Falling back to generic'
'migration.')
return refuse_to_migrate return refuse_to_migrate
if (host['capabilities']['storage_protocol'] != 'ceph'): if (host['capabilities']['storage_protocol'] != 'ceph'):
@ -1864,6 +1866,16 @@ class RBDDriver(driver.CloneableImageVD, driver.MigrateVD,
'Falling back to generic migration.') 'Falling back to generic migration.')
return refuse_to_migrate return refuse_to_migrate
if rbd_pool == self.configuration.rbd_pool:
LOG.debug('Migration in the same pool, just need to update'
'volumes host value to destination host.')
return (True, None)
if volume.status == 'in-use':
LOG.debug('Migration in-use volume between different pools.'
'Falling back to generic migration.')
return refuse_to_migrate
with RBDVolumeProxy(self, volume.name, read_only=True) as source: with RBDVolumeProxy(self, volume.name, read_only=True) as source:
try: try:
source.copy(target.ioctx, volume.name) source.copy(target.ioctx, volume.name)

View File

@ -0,0 +1,5 @@
---
fixes:
- |
Fix volume migration fails in the same ceph RBD pool. `Bug 1871524
<https://bugs.launchpad.net/cinder/+bug/1871524>`__.