error warning:
2021-02-03 12:44:04.266 62258 WARNING cinder.scheduler.filter_scheduler [req-1435cf62-db08-49f9-a0ce-6a1545042964 b12c3b14ae8240ed86218d81caa42e95 4f5d321fa88a432ebb961c20e651cf84 - default default] No weighed backend found for volume with properties: {'name': u'multiattach', 'qos_specs_id': None, 'deleted': False, 'created_at': '2021-02-02T02:35:53.000000', 'updated_at': None, 'extra_specs': {u'volume_backend_name': u'nfs', u'multiattach': u'<is> True'}, 'is_public': True, 'deleted_at': None, 'id': u'c049ba68-e223-463d-a26f-075b3c6136cf', 'projects': [], 'description': None}
2021-02-03 12:44:04.267 62258 INFO cinder.message.api [req-1435cf62-db08-49f9-a0ce-6a1545042964 b12c3b14ae8240ed86218d81caa42e95 4f5d321fa88a432ebb961c20e651cf84 - default default] Creating message record for request_id = req-1435cf62-db08-49f9-a0ce-6a1545042964
2021-02-03 12:44:04.289 62258 ERROR cinder.scheduler.flows.create_volume [req-1435cf62-db08-49f9-a0ce-6a1545042964 b12c3b14ae8240ed86218d81caa42e95 4f5d321fa88a432ebb961c20e651cf84 - default default] Failed to run task cinder.scheduler.flows.create_volume.ScheduleCreateVolumeTask;volume:create: No valid backend was found. No weighed backends available: NoValidBackend: No valid backend was found. No weighed backends available
从debug信息可以知道,cinder节点的backends不支持multiattach的capability 属性
debug信息:
2021-02-03 12:44:04.260 62258 DEBUG cinder.scheduler.filters.capabilities_filter [req-1435cf62-db08-49f9-a0ce-6a1545042964 b12c3b14ae8240ed86218d81caa42e95 4f5d321fa88a432ebb961c20e651cf84 - default default] Backend doesn't provide capability 'multiattach' _satisfies_extra_specs /usr/lib/python2.7/site-packages/cinder/scheduler/filters/capabilities_filter.py:75
解决方法:修改nfs driver的_update_volume_stats函数,添加data["multiattach"] = True,修改后如下:
路径:/usr/lib/python2.7/site-packages/cinder/volume/drivers/nfs.py
def _update_volume_stats(self):
"""Retrieve stats info from volume group."""
super(NfsDriver, self)._update_volume_stats()
self._stats['sparse_copy_volume'] = True
data = self._stats
global_capacity = data['total_capacity_gb']
global_free = data['free_capacity_gb']
thin_enabled = self.configuration.nfs_sparsed_volumes
if thin_enabled:
provisioned_capacity = self._get_provisioned_capacity()
else:
provisioned_capacity = round(global_capacity - global_free, 2)
data['provisioned_capacity_gb'] = provisioned_capacity
data['max_over_subscription_ratio'] = self.max_over_subscription_ratio
data['reserved_percentage'] = self.reserved_percentage
data['thin_provisioning_support'] = thin_enabled
data['thick_provisioning_support'] = not thin_enabled
data["multiattach"] = True
self._stats = data