DRBD: Disk-options for new resources

Set some more default options, to provide better performance
out-of-the-box.

DocImpact
Change-Id: Icf3eefd03d755dd14a623f2febf6c3df87a1b083
This commit is contained in:
Philipp Marek 2016-07-28 15:05:34 +02:00
parent d2fc448d23
commit f1b9919136
3 changed files with 178 additions and 121 deletions

View File

@ -143,6 +143,17 @@ class DrbdManageFakeDriver(object):
def __init__(self): def __init__(self):
self.calls = [] self.calls = []
self.cur = -1
def call_count(self):
return len(self.calls)
def next_call(self):
self.cur += 1
return self.calls[self.cur][0]
def call_parm(self, arg_idx):
return self.calls[self.cur][arg_idx]
def run_external_plugin(self, name, props): def run_external_plugin(self, name, props):
self.calls.append(["run_external_plugin", name, props]) self.calls.append(["run_external_plugin", name, props])
@ -270,6 +281,10 @@ class DrbdManageFakeDriver(object):
self.calls.append(["set_drbdsetup_props", options]) self.calls.append(["set_drbdsetup_props", options])
return [[mock_dm_exc.DM_SUCCESS, "ack", []]] return [[mock_dm_exc.DM_SUCCESS, "ack", []]]
def modify_resource(self, res, ser, props):
self.calls.append(["modify_resource", res, ser, props])
return [[mock_dm_exc.DM_SUCCESS, "ack", []]]
class DrbdManageIscsiTestCase(test.TestCase): class DrbdManageIscsiTestCase(test.TestCase):
@ -291,6 +306,8 @@ class DrbdManageIscsiTestCase(test.TestCase):
'"ko-count": "30"}') '"ko-count": "30"}')
if key == 'drbdmanage_resource_options': if key == 'drbdmanage_resource_options':
return '{"auto-promote-timeout": "300"}' return '{"auto-promote-timeout": "300"}'
if key == 'drbdmanage_disk_options':
return '{"c-min-rate": "4M"}'
return self._fake_safe_get(key) return self._fake_safe_get(key)
@ -356,14 +373,15 @@ class DrbdManageIscsiTestCase(test.TestCase):
dmd.drbdmanage_devs_on_controller = False dmd.drbdmanage_devs_on_controller = False
dmd.odm = DrbdManageFakeDriver() dmd.odm = DrbdManageFakeDriver()
dmd.create_volume(testvol) dmd.create_volume(testvol)
self.assertEqual("create_resource", dmd.odm.calls[0][0]) self.assertEqual(8, dmd.odm.call_count())
self.assertEqual("set_drbdsetup_props", dmd.odm.calls[1][0]) self.assertEqual("create_resource", dmd.odm.next_call())
self.assertEqual("set_drbdsetup_props", dmd.odm.calls[2][0]) self.assertEqual("set_drbdsetup_props", dmd.odm.next_call())
self.assertEqual("list_volumes", dmd.odm.calls[3][0]) self.assertEqual("set_drbdsetup_props", dmd.odm.next_call())
self.assertEqual("create_volume", dmd.odm.calls[4][0]) self.assertEqual("set_drbdsetup_props", dmd.odm.next_call())
self.assertEqual(1048576, dmd.odm.calls[4][2]) self.assertEqual("list_volumes", dmd.odm.next_call())
self.assertEqual("auto_deploy", dmd.odm.calls[5][0]) self.assertEqual("create_volume", dmd.odm.next_call())
self.assertEqual(7, len(dmd.odm.calls)) self.assertEqual(1048576, dmd.odm.call_parm(2))
self.assertEqual("auto_deploy", dmd.odm.next_call())
def test_create_volume_with_options(self): def test_create_volume_with_options(self):
testvol = {'project_id': 'testprjid', testvol = {'project_id': 'testprjid',
@ -379,21 +397,28 @@ class DrbdManageIscsiTestCase(test.TestCase):
dmd.odm = DrbdManageFakeDriver() dmd.odm = DrbdManageFakeDriver()
dmd.create_volume(testvol) dmd.create_volume(testvol)
self.assertEqual("create_resource", dmd.odm.calls[0][0]) self.assertEqual(8, dmd.odm.call_count())
self.assertEqual("set_drbdsetup_props", dmd.odm.calls[1][0]) self.assertEqual("create_resource", dmd.odm.next_call())
self.assertEqual("reso", dmd.odm.calls[1][1]["type"])
self.assertEqual("300", dmd.odm.calls[1][1]["auto-promote-timeout"])
self.assertEqual("set_drbdsetup_props", dmd.odm.calls[2][0]) self.assertEqual("set_drbdsetup_props", dmd.odm.next_call())
self.assertEqual("neto", dmd.odm.calls[2][1]["type"]) self.assertEqual("reso", dmd.odm.call_parm(1)["type"])
self.assertEqual("30", dmd.odm.calls[2][1]["ko-count"]) self.assertEqual("300", dmd.odm.call_parm(1)["auto-promote-timeout"])
self.assertEqual("list_volumes", dmd.odm.calls[3][0]) self.assertEqual("set_drbdsetup_props", dmd.odm.next_call())
self.assertEqual("create_volume", dmd.odm.calls[4][0]) self.assertEqual("neto", dmd.odm.call_parm(1)["type"])
self.assertEqual(1048576, dmd.odm.calls[4][2]) self.assertEqual("30", dmd.odm.call_parm(1)["ko-count"])
self.assertEqual("auto_deploy", dmd.odm.calls[5][0])
self.assertEqual(7, len(dmd.odm.calls)) self.assertEqual("set_drbdsetup_props", dmd.odm.next_call())
self.assertEqual("disko", dmd.odm.call_parm(1)["type"])
self.assertEqual("4M", dmd.odm.call_parm(1)["c-min-rate"])
self.assertEqual("list_volumes", dmd.odm.next_call())
self.assertEqual("create_volume", dmd.odm.next_call())
self.assertEqual(1048576, dmd.odm.call_parm(2))
self.assertEqual("auto_deploy", dmd.odm.next_call())
def test_create_volume_controller_all_vols(self): def test_create_volume_controller_all_vols(self):
testvol = {'project_id': 'testprjid', testvol = {'project_id': 'testprjid',
@ -407,16 +432,17 @@ class DrbdManageIscsiTestCase(test.TestCase):
dmd.drbdmanage_devs_on_controller = True dmd.drbdmanage_devs_on_controller = True
dmd.odm = DrbdManageFakeDriver() dmd.odm = DrbdManageFakeDriver()
dmd.create_volume(testvol) dmd.create_volume(testvol)
self.assertEqual(8, len(dmd.odm.calls)) self.assertEqual("create_resource", dmd.odm.next_call())
self.assertEqual("create_resource", dmd.odm.calls[0][0]) self.assertEqual("set_drbdsetup_props", dmd.odm.next_call())
self.assertEqual("set_drbdsetup_props", dmd.odm.calls[1][0]) self.assertEqual("set_drbdsetup_props", dmd.odm.next_call())
self.assertEqual("set_drbdsetup_props", dmd.odm.calls[2][0]) self.assertEqual("set_drbdsetup_props", dmd.odm.next_call())
self.assertEqual("list_volumes", dmd.odm.calls[3][0]) self.assertEqual("list_volumes", dmd.odm.next_call())
self.assertEqual("create_volume", dmd.odm.calls[4][0]) self.assertEqual("create_volume", dmd.odm.next_call())
self.assertEqual(1048576, dmd.odm.calls[4][2]) self.assertEqual(1048576, dmd.odm.call_parm(2))
self.assertEqual("auto_deploy", dmd.odm.calls[5][0]) self.assertEqual("auto_deploy", dmd.odm.next_call())
self.assertEqual("run_external_plugin", dmd.odm.calls[6][0]) self.assertEqual("run_external_plugin", dmd.odm.next_call())
self.assertEqual("assign", dmd.odm.calls[7][0]) self.assertEqual("assign", dmd.odm.next_call())
self.assertEqual(9, dmd.odm.call_count())
def test_delete_volume(self): def test_delete_volume(self):
testvol = {'project_id': 'testprjid', testvol = {'project_id': 'testprjid',
@ -429,9 +455,9 @@ class DrbdManageIscsiTestCase(test.TestCase):
dmd = drv.DrbdManageIscsiDriver(configuration=self.configuration) dmd = drv.DrbdManageIscsiDriver(configuration=self.configuration)
dmd.odm = DrbdManageFakeDriver() dmd.odm = DrbdManageFakeDriver()
dmd.delete_volume(testvol) dmd.delete_volume(testvol)
self.assertEqual("list_volumes", dmd.odm.calls[0][0]) self.assertEqual("list_volumes", dmd.odm.next_call())
self.assertEqual(testvol['id'], dmd.odm.calls[0][3]["aux:cinder-id"]) self.assertEqual(testvol['id'], dmd.odm.call_parm(3)["aux:cinder-id"])
self.assertEqual("remove_volume", dmd.odm.calls[1][0]) self.assertEqual("remove_volume", dmd.odm.next_call())
def test_local_path(self): def test_local_path(self):
testvol = {'project_id': 'testprjid', testvol = {'project_id': 'testprjid',
@ -453,10 +479,10 @@ class DrbdManageIscsiTestCase(test.TestCase):
dmd = drv.DrbdManageIscsiDriver(configuration=self.configuration) dmd = drv.DrbdManageIscsiDriver(configuration=self.configuration)
dmd.odm = DrbdManageFakeDriver() dmd.odm = DrbdManageFakeDriver()
dmd.create_snapshot(testsnap) dmd.create_snapshot(testsnap)
self.assertEqual("list_volumes", dmd.odm.calls[0][0]) self.assertEqual("list_volumes", dmd.odm.next_call())
self.assertEqual("list_assignments", dmd.odm.calls[1][0]) self.assertEqual("list_assignments", dmd.odm.next_call())
self.assertEqual("create_snapshot", dmd.odm.calls[2][0]) self.assertEqual("create_snapshot", dmd.odm.next_call())
self.assertIn('node', dmd.odm.calls[2][3]) self.assertIn('node', dmd.odm.call_parm(3))
def test_delete_snapshot(self): def test_delete_snapshot(self):
testsnap = {'id': 'ca253fd0-8068-11e4-98c0-5254008ea111'} testsnap = {'id': 'ca253fd0-8068-11e4-98c0-5254008ea111'}
@ -464,8 +490,8 @@ class DrbdManageIscsiTestCase(test.TestCase):
dmd = drv.DrbdManageIscsiDriver(configuration=self.configuration) dmd = drv.DrbdManageIscsiDriver(configuration=self.configuration)
dmd.odm = DrbdManageFakeDriver() dmd.odm = DrbdManageFakeDriver()
dmd.delete_snapshot(testsnap) dmd.delete_snapshot(testsnap)
self.assertEqual("list_snapshots", dmd.odm.calls[0][0]) self.assertEqual("list_snapshots", dmd.odm.next_call())
self.assertEqual("remove_snapshot", dmd.odm.calls[1][0]) self.assertEqual("remove_snapshot", dmd.odm.next_call())
def test_extend_volume(self): def test_extend_volume(self):
testvol = {'project_id': 'testprjid', testvol = {'project_id': 'testprjid',
@ -478,13 +504,13 @@ class DrbdManageIscsiTestCase(test.TestCase):
dmd = drv.DrbdManageIscsiDriver(configuration=self.configuration) dmd = drv.DrbdManageIscsiDriver(configuration=self.configuration)
dmd.odm = DrbdManageFakeDriver() dmd.odm = DrbdManageFakeDriver()
dmd.extend_volume(testvol, 5) dmd.extend_volume(testvol, 5)
self.assertEqual("list_volumes", dmd.odm.calls[0][0]) self.assertEqual("list_volumes", dmd.odm.next_call())
self.assertEqual(testvol['id'], dmd.odm.calls[0][3]["aux:cinder-id"]) self.assertEqual(testvol['id'], dmd.odm.call_parm(3)["aux:cinder-id"])
self.assertEqual("resize_volume", dmd.odm.calls[1][0]) self.assertEqual("resize_volume", dmd.odm.next_call())
self.assertEqual("res", dmd.odm.calls[1][1]) self.assertEqual("res", dmd.odm.call_parm(1))
self.assertEqual(2, dmd.odm.calls[1][2]) self.assertEqual(2, dmd.odm.call_parm(2))
self.assertEqual(-1, dmd.odm.calls[1][3]) self.assertEqual(-1, dmd.odm.call_parm(3))
self.assertEqual(5242880, dmd.odm.calls[1][4]) self.assertEqual(5242880, dmd.odm.call_parm(4))
def test_create_cloned_volume(self): def test_create_cloned_volume(self):
srcvol = {'project_id': 'testprjid', srcvol = {'project_id': 'testprjid',
@ -499,15 +525,18 @@ class DrbdManageIscsiTestCase(test.TestCase):
dmd = drv.DrbdManageIscsiDriver(configuration=self.configuration) dmd = drv.DrbdManageIscsiDriver(configuration=self.configuration)
dmd.odm = DrbdManageFakeDriver() dmd.odm = DrbdManageFakeDriver()
dmd.create_cloned_volume(newvol, srcvol) dmd.create_cloned_volume(newvol, srcvol)
self.assertEqual("list_volumes", dmd.odm.calls[0][0]) self.assertEqual("list_volumes", dmd.odm.next_call())
self.assertEqual("list_assignments", dmd.odm.calls[1][0]) self.assertEqual("list_assignments", dmd.odm.next_call())
self.assertEqual("create_snapshot", dmd.odm.calls[2][0]) self.assertEqual("create_snapshot", dmd.odm.next_call())
self.assertEqual("run_external_plugin", dmd.odm.calls[3][0]) self.assertEqual("run_external_plugin", dmd.odm.next_call())
self.assertEqual("list_snapshots", dmd.odm.calls[4][0]) self.assertEqual("list_snapshots", dmd.odm.next_call())
self.assertEqual("restore_snapshot", dmd.odm.calls[5][0]) self.assertEqual("restore_snapshot", dmd.odm.next_call())
self.assertEqual("run_external_plugin", dmd.odm.calls[6][0]) self.assertEqual("set_drbdsetup_props", dmd.odm.next_call())
self.assertEqual("list_snapshots", dmd.odm.calls[7][0]) self.assertEqual("set_drbdsetup_props", dmd.odm.next_call())
self.assertEqual("remove_snapshot", dmd.odm.calls[8][0]) self.assertEqual("set_drbdsetup_props", dmd.odm.next_call())
self.assertEqual("run_external_plugin", dmd.odm.next_call())
self.assertEqual("list_snapshots", dmd.odm.next_call())
self.assertEqual("remove_snapshot", dmd.odm.next_call())
def test_create_cloned_volume_larger_size(self): def test_create_cloned_volume_larger_size(self):
srcvol = {'project_id': 'testprjid', srcvol = {'project_id': 'testprjid',
@ -523,25 +552,30 @@ class DrbdManageIscsiTestCase(test.TestCase):
dmd = drv.DrbdManageIscsiDriver(configuration=self.configuration) dmd = drv.DrbdManageIscsiDriver(configuration=self.configuration)
dmd.odm = DrbdManageFakeDriver() dmd.odm = DrbdManageFakeDriver()
dmd.create_cloned_volume(newvol, srcvol) dmd.create_cloned_volume(newvol, srcvol)
self.assertEqual("list_volumes", dmd.odm.calls[0][0]) self.assertEqual("list_volumes", dmd.odm.next_call())
self.assertEqual("list_assignments", dmd.odm.calls[1][0]) self.assertEqual("list_assignments", dmd.odm.next_call())
self.assertEqual("create_snapshot", dmd.odm.calls[2][0]) self.assertEqual("create_snapshot", dmd.odm.next_call())
self.assertEqual("run_external_plugin", dmd.odm.calls[3][0]) self.assertEqual("run_external_plugin", dmd.odm.next_call())
self.assertEqual("list_snapshots", dmd.odm.calls[4][0]) self.assertEqual("list_snapshots", dmd.odm.next_call())
self.assertEqual("restore_snapshot", dmd.odm.calls[5][0]) self.assertEqual("restore_snapshot", dmd.odm.next_call())
self.assertEqual("run_external_plugin", dmd.odm.calls[6][0]) self.assertEqual("set_drbdsetup_props", dmd.odm.next_call())
# resize image checks self.assertEqual("set_drbdsetup_props", dmd.odm.next_call())
self.assertEqual("list_volumes", dmd.odm.calls[7][0]) self.assertEqual("set_drbdsetup_props", dmd.odm.next_call())
self.assertEqual(newvol['id'], dmd.odm.calls[7][3]["aux:cinder-id"]) self.assertEqual("run_external_plugin", dmd.odm.next_call())
self.assertEqual("resize_volume", dmd.odm.calls[8][0])
self.assertEqual("res", dmd.odm.calls[8][1])
self.assertEqual(2, dmd.odm.calls[8][2])
self.assertEqual(-1, dmd.odm.calls[8][3])
self.assertEqual(5242880, dmd.odm.calls[8][4])
self.assertEqual("run_external_plugin", dmd.odm.calls[9][0]) # resize image checks
self.assertEqual("list_snapshots", dmd.odm.calls[10][0]) self.assertEqual("list_volumes", dmd.odm.next_call())
self.assertEqual("remove_snapshot", dmd.odm.calls[11][0]) self.assertEqual(newvol['id'], dmd.odm.call_parm(3)["aux:cinder-id"])
self.assertEqual("resize_volume", dmd.odm.next_call())
self.assertEqual("res", dmd.odm.call_parm(1))
self.assertEqual(2, dmd.odm.call_parm(2))
self.assertEqual(-1, dmd.odm.call_parm(3))
self.assertEqual(5242880, dmd.odm.call_parm(4))
self.assertEqual("run_external_plugin", dmd.odm.next_call())
self.assertEqual("list_snapshots", dmd.odm.next_call())
self.assertEqual("remove_snapshot", dmd.odm.next_call())
def test_create_volume_from_snapshot(self): def test_create_volume_from_snapshot(self):
snap = {'project_id': 'testprjid', snap = {'project_id': 'testprjid',
@ -556,9 +590,12 @@ class DrbdManageIscsiTestCase(test.TestCase):
dmd = drv.DrbdManageIscsiDriver(configuration=self.configuration) dmd = drv.DrbdManageIscsiDriver(configuration=self.configuration)
dmd.odm = DrbdManageFakeDriver() dmd.odm = DrbdManageFakeDriver()
dmd.create_volume_from_snapshot(newvol, snap) dmd.create_volume_from_snapshot(newvol, snap)
self.assertEqual("list_snapshots", dmd.odm.calls[0][0]) self.assertEqual("list_snapshots", dmd.odm.next_call())
self.assertEqual("restore_snapshot", dmd.odm.calls[1][0]) self.assertEqual("restore_snapshot", dmd.odm.next_call())
self.assertEqual("run_external_plugin", dmd.odm.calls[2][0]) self.assertEqual("set_drbdsetup_props", dmd.odm.next_call())
self.assertEqual("set_drbdsetup_props", dmd.odm.next_call())
self.assertEqual("set_drbdsetup_props", dmd.odm.next_call())
self.assertEqual("run_external_plugin", dmd.odm.next_call())
def test_create_volume_from_snapshot_larger_size(self): def test_create_volume_from_snapshot_larger_size(self):
snap = {'project_id': 'testprjid', snap = {'project_id': 'testprjid',
@ -574,18 +611,12 @@ class DrbdManageIscsiTestCase(test.TestCase):
dmd = drv.DrbdManageIscsiDriver(configuration=self.configuration) dmd = drv.DrbdManageIscsiDriver(configuration=self.configuration)
dmd.odm = DrbdManageFakeDriver() dmd.odm = DrbdManageFakeDriver()
dmd.create_volume_from_snapshot(newvol, snap) dmd.create_volume_from_snapshot(newvol, snap)
self.assertEqual("list_snapshots", dmd.odm.calls[0][0]) self.assertEqual("list_snapshots", dmd.odm.next_call())
self.assertEqual("restore_snapshot", dmd.odm.calls[1][0]) self.assertEqual("restore_snapshot", dmd.odm.next_call())
self.assertEqual("run_external_plugin", dmd.odm.calls[2][0]) self.assertEqual("set_drbdsetup_props", dmd.odm.next_call())
self.assertEqual("set_drbdsetup_props", dmd.odm.next_call())
# resize image checks self.assertEqual("set_drbdsetup_props", dmd.odm.next_call())
self.assertEqual("list_volumes", dmd.odm.calls[3][0]) self.assertEqual("run_external_plugin", dmd.odm.next_call())
self.assertEqual(newvol['id'], dmd.odm.calls[3][3]["aux:cinder-id"])
self.assertEqual("resize_volume", dmd.odm.calls[4][0])
self.assertEqual("res", dmd.odm.calls[4][1])
self.assertEqual(2, dmd.odm.calls[4][2])
self.assertEqual(-1, dmd.odm.calls[4][3])
self.assertEqual(5242880, dmd.odm.calls[4][4])
class DrbdManageDrbdTestCase(DrbdManageIscsiTestCase): class DrbdManageDrbdTestCase(DrbdManageIscsiTestCase):
@ -612,12 +643,12 @@ class DrbdManageDrbdTestCase(DrbdManageIscsiTestCase):
dmd.odm = DrbdManageFakeDriver() dmd.odm = DrbdManageFakeDriver()
x = dmd.create_export({}, volume, connector) x = dmd.create_export({}, volume, connector)
self.assertEqual("list_volumes", dmd.odm.calls[0][0]) self.assertEqual("list_volumes", dmd.odm.next_call())
self.assertEqual("create_node", dmd.odm.calls[1][0]) self.assertEqual("create_node", dmd.odm.next_call())
self.assertEqual("assign", dmd.odm.calls[2][0]) self.assertEqual("assign", dmd.odm.next_call())
# local_path # local_path
self.assertEqual("list_volumes", dmd.odm.calls[3][0]) self.assertEqual("list_volumes", dmd.odm.next_call())
self.assertEqual("text_query", dmd.odm.calls[4][0]) self.assertEqual("text_query", dmd.odm.next_call())
self.assertEqual("local", x["driver_volume_type"]) self.assertEqual("local", x["driver_volume_type"])
@ -633,11 +664,11 @@ class DrbdManageCommonTestCase(DrbdManageIscsiTestCase):
{'retry': 4, {'retry': 4,
'run-into-timeout': True}) 'run-into-timeout': True})
self.assertFalse(res) self.assertFalse(res)
self.assertEqual(4, len(dmd.odm.calls)) self.assertEqual(4, dmd.odm.call_count())
self.assertEqual("run_external_plugin", dmd.odm.calls[0][0]) self.assertEqual("run_external_plugin", dmd.odm.next_call())
self.assertEqual("run_external_plugin", dmd.odm.calls[1][0]) self.assertEqual("run_external_plugin", dmd.odm.next_call())
self.assertEqual("run_external_plugin", dmd.odm.calls[2][0]) self.assertEqual("run_external_plugin", dmd.odm.next_call())
self.assertEqual("run_external_plugin", dmd.odm.calls[3][0]) self.assertEqual("run_external_plugin", dmd.odm.next_call())
def test_drbd_policy_loop_success(self): def test_drbd_policy_loop_success(self):
dmd = drv.DrbdManageDrbdDriver(configuration=self.configuration) dmd = drv.DrbdManageDrbdDriver(configuration=self.configuration)
@ -648,11 +679,11 @@ class DrbdManageCommonTestCase(DrbdManageIscsiTestCase):
'retry': 4}, 'retry': 4},
{'override': 'xyz'}) {'override': 'xyz'})
self.assertTrue(res) self.assertTrue(res)
self.assertEqual(4, len(dmd.odm.calls)) self.assertEqual(4, dmd.odm.call_count())
self.assertEqual("run_external_plugin", dmd.odm.calls[0][0]) self.assertEqual("run_external_plugin", dmd.odm.next_call())
self.assertEqual("run_external_plugin", dmd.odm.calls[1][0]) self.assertEqual("run_external_plugin", dmd.odm.next_call())
self.assertEqual("run_external_plugin", dmd.odm.calls[2][0]) self.assertEqual("run_external_plugin", dmd.odm.next_call())
self.assertEqual("run_external_plugin", dmd.odm.calls[3][0]) self.assertEqual("run_external_plugin", dmd.odm.next_call())
def test_drbd_policy_loop_simple(self): def test_drbd_policy_loop_simple(self):
dmd = drv.DrbdManageDrbdDriver(configuration=self.configuration) dmd = drv.DrbdManageDrbdDriver(configuration=self.configuration)
@ -665,11 +696,11 @@ class DrbdManageCommonTestCase(DrbdManageIscsiTestCase):
'starttime': 0}) 'starttime': 0})
self.assertTrue(res) self.assertTrue(res)
self.assertEqual(1, len(dmd.odm.calls)) self.assertEqual(1, dmd.odm.call_count())
self.assertEqual("run_external_plugin", dmd.odm.calls[0][0]) self.assertEqual("run_external_plugin", dmd.odm.next_call())
self.assertEqual('policy-name', dmd.odm.calls[0][1]) self.assertEqual('policy-name', dmd.odm.call_parm(1))
incoming = dmd.odm.call_parm(2)
incoming = dmd.odm.calls[0][2]
self.assertGreaterEqual(4, abs(float(incoming['starttime']) - self.assertGreaterEqual(4, abs(float(incoming['starttime']) -
time.time())) time.time()))
self.assertEqual('value', incoming['base']) self.assertEqual('value', incoming['base'])

View File

@ -63,9 +63,15 @@ drbd_opts = [
cfg.StrOpt('drbdmanage_resource_policy', cfg.StrOpt('drbdmanage_resource_policy',
default='{"ratio": "0.51", "timeout": "60"}', default='{"ratio": "0.51", "timeout": "60"}',
help='Resource deployment completion wait policy.'), help='Resource deployment completion wait policy.'),
cfg.StrOpt('drbdmanage_disk_options',
default='{"c-min-rate": "4M"}',
help='Disk options to set on new resources. '
'See http://www.drbd.org/en/doc/users-guide-90/re-drbdconf'
' for all the details.'),
cfg.StrOpt('drbdmanage_net_options', cfg.StrOpt('drbdmanage_net_options',
default='{"connect-int": "4", "allow-two-primaries": "yes", ' default='{"connect-int": "4", "allow-two-primaries": "yes", '
'"ko-count": "30"}', '"ko-count": "30", "max-buffers": "20000", '
'"ping-timeout": "100"}',
help='Net options to set on new resources. ' help='Net options to set on new resources. '
'See http://www.drbd.org/en/doc/users-guide-90/re-drbdconf' 'See http://www.drbd.org/en/doc/users-guide-90/re-drbdconf'
' for all the details.'), ' for all the details.'),
@ -158,6 +164,8 @@ class DrbdManageBaseDriver(driver.VolumeDriver):
self.configuration.safe_get('drbdmanage_resource_options')) self.configuration.safe_get('drbdmanage_resource_options'))
self.net_options = js_decoder.decode( self.net_options = js_decoder.decode(
self.configuration.safe_get('drbdmanage_net_options')) self.configuration.safe_get('drbdmanage_net_options'))
self.disk_options = js_decoder.decode(
self.configuration.safe_get('drbdmanage_disk_options'))
self.plugin_resource = self.configuration.safe_get( self.plugin_resource = self.configuration.safe_get(
'drbdmanage_resource_plugin') 'drbdmanage_resource_plugin')
@ -467,6 +475,28 @@ class DrbdManageBaseDriver(driver.VolumeDriver):
message = _('Got bad path information from DRBDmanage! (%s)') % data message = _('Got bad path information from DRBDmanage! (%s)') % data
raise exception.VolumeBackendAPIException(data=message) raise exception.VolumeBackendAPIException(data=message)
def _push_drbd_options(self, d_res_name):
res_opt = {'resource': d_res_name,
'target': 'resource',
'type': 'reso'}
res_opt.update(self.resource_options)
res = self.call_or_reconnect(self.odm.set_drbdsetup_props, res_opt)
self._check_result(res)
res_opt = {'resource': d_res_name,
'target': 'resource',
'type': 'neto'}
res_opt.update(self.net_options)
res = self.call_or_reconnect(self.odm.set_drbdsetup_props, res_opt)
self._check_result(res)
res_opt = {'resource': d_res_name,
'target': 'resource',
'type': 'disko'}
res_opt.update(self.disk_options)
res = self.call_or_reconnect(self.odm.set_drbdsetup_props, res_opt)
self._check_result(res)
def create_volume(self, volume): def create_volume(self, volume):
"""Creates a DRBD resource. """Creates a DRBD resource.
@ -482,19 +512,7 @@ class DrbdManageBaseDriver(driver.VolumeDriver):
self.empty_dict) self.empty_dict)
self._check_result(res, ignore=[dm_exc.DM_EEXIST], ret=None) self._check_result(res, ignore=[dm_exc.DM_EEXIST], ret=None)
res_opt = {'resource': d_res_name, self._push_drbd_options(d_res_name)
'target': 'resource',
'type': 'reso'}
res_opt.update(self.resource_options)
res = self.call_or_reconnect(self.odm.set_drbdsetup_props, res_opt)
self._check_result(res)
res_opt = {'resource': d_res_name,
'target': 'resource',
'type': 'neto'}
res_opt.update(self.net_options)
res = self.call_or_reconnect(self.odm.set_drbdsetup_props, res_opt)
self._check_result(res)
# If we get DM_EEXIST, then the volume already exists, eg. because # If we get DM_EEXIST, then the volume already exists, eg. because
# deploy gave an error on a previous try (like ENOSPC). # deploy gave an error on a previous try (like ENOSPC).
@ -604,6 +622,8 @@ class DrbdManageBaseDriver(driver.VolumeDriver):
v_props) v_props)
self._check_result(res, ignore=[dm_exc.DM_ENOENT]) self._check_result(res, ignore=[dm_exc.DM_ENOENT])
self._push_drbd_options(d_res_name)
# TODO(PM): CG # TODO(PM): CG
okay = self._call_policy_plugin(self.plugin_resource, okay = self._call_policy_plugin(self.plugin_resource,
self.policy_resource, self.policy_resource,

View File

@ -0,0 +1,6 @@
---
features:
- Configuration options for the DRBD driver that will be
applied to DRBD resources; the default values should
be okay for most installations.