connector
– Connector¶
Brick Connector objects for each supported transport protocol.
The connectors here are responsible for discovering and removing volumes for each of the supported transport protocols.
- class os_brick.initiator.connector.InitiatorConnector¶
- static factory(protocol, root_helper, driver=None, use_multipath=False, device_scan_attempts=3, arch=None, *args, **kwargs)¶
Build a Connector object based upon protocol and architecture.
- class os_brick.initiator.connector.ISCSIConnector(root_helper: str, driver=None, execute=None, use_multipath: bool = False, device_scan_attempts: int = 3, transport: str = 'default', *args, **kwargs)¶
Connector class to attach/detach iSCSI volumes.
- connect_volume(connection_properties: dict) Optional[dict[str, str]] ¶
Attach the volume to instance_name.
- Parameters
connection_properties (dict) – The valid dictionary that describes all of the target volume attributes.
- Returns
dict
connection_properties for iSCSI must include: target_portal(s) - ip and optional port target_iqn(s) - iSCSI Qualified Name target_lun(s) - LUN id of the volume Note that plural keys may be used when use_multipath=True
- disconnect_volume(connection_properties: dict, device_info: dict, force: bool = False, ignore_errors: bool = False) None ¶
Detach the volume from instance_name.
- Parameters
connection_properties (dict that must include: target_portal(s) - IP and optional port target_iqn(s) - iSCSI Qualified Name target_lun(s) - LUN id of the volume) – The dictionary that describes all of the target volume attributes.
device_info (dict) – historical difference, but same as connection_props
force (bool) – Whether to forcefully disconnect even if flush fails.
ignore_errors (bool) – When force is True, this will decide whether to ignore errors or raise an exception once finished the operation. Default is False.
- class os_brick.initiator.connector.FibreChannelConnector(root_helper: str, driver=None, execute: Optional[str] = None, use_multipath: bool = False, device_scan_attempts: int = 3, *args, **kwargs)¶
Connector class to attach/detach Fibre Channel volumes.
- connect_volume(connection_properties: dict) dict ¶
Attach the volume to instance_name.
- Parameters
connection_properties (dict) – The dictionary that describes all of the target volume attributes.
- Returns
dict
connection_properties for Fibre Channel must include: target_wwn - World Wide Name target_lun - LUN id of the volume
- disconnect_volume(connection_properties: dict, device_info: dict, force: bool = False, ignore_errors: bool = False) None ¶
Detach the volume from instance_name.
- Parameters
connection_properties (dict) – The dictionary that describes all of the target volume attributes.
device_info (dict) – historical difference, but same as connection_props
connection_properties for Fibre Channel must include: target_wwn - World Wide Name target_lun - LUN id of the volume
- class os_brick.initiator.connector.LocalConnector(root_helper, driver=None, *args, **kwargs)¶
“Connector class to attach/detach File System backed volumes.
- connect_volume(connection_properties: dict) dict ¶
Connect to a volume.
- Parameters
connection_properties (dict) –
The dictionary that describes all of the target volume attributes.
connection_properties
must include:device_path
- path to the volume to be connected
- Returns
dict
- disconnect_volume(connection_properties, device_info, force=False, ignore_errors=False)¶
Disconnect a volume from the local host.
- Parameters
connection_properties (dict) – The dictionary that describes all of the target volume attributes.
device_info (dict) – historical difference, but same as connection_props
- class os_brick.initiator.connector.HuaweiStorHyperConnector(root_helper, driver=None, *args, **kwargs)¶
“Connector class to attach/detach SDSHypervisor volumes.
- connect_volume(connection_properties)¶
Connect to a volume.
- Parameters
connection_properties (dict) – The dictionary that describes all of the target volume attributes.
- Returns
dict
- disconnect_volume(connection_properties, device_info, force=False, ignore_errors=False)¶
Disconnect a volume from the local host.
- Parameters
connection_properties (dict) – The dictionary that describes all of the target volume attributes.
device_info (dict) – historical difference, but same as connection_props
- class os_brick.initiator.connectors.nvmeof.NVMeOFConnector(root_helper: str, driver: Optional[os_brick.initiator.host_driver.HostDriver] = None, use_multipath: bool = False, device_scan_attempts: int = 5, *args, **kwargs)¶
Connector class to attach/detach NVMe-oF volumes.
- connect_volume(connection_properties: os_brick.initiator.connectors.nvmeof.NVMeOFConnProps) dict[str, str] ¶
Attach and discover the volume.
- disconnect_volume(connection_properties: dict, device_info: dict[str, str], force: bool = False, ignore_errors: bool = False) None ¶
Flush the volume.
Disconnect of volumes happens on storage system side. Here we could remove connections to subsystems if no volumes are left. But new volumes can pop up asynchronously in the meantime. So the only thing left is flushing or disassembly of a correspondng RAID device.
- Parameters
connection_properties (dict) – The dictionary that describes all of the target volume attributes as described in connect_volume but also with the “device_path” key containing the path to the volume that was connected (this is added by Nova).
device_info (dict) – historical difference, but same as connection_props
- extend_volume(connection_properties: dict[str, str]) int ¶
Update an attached volume to reflect the current size after extend
The only way to reflect the new size of an NVMe-oF volume on the host is a rescan, which rescans the whole subsystem. This is a problem on attach_volume and detach_volume, but not here, since we will have at least the namespace we are operating on in the subsystem.
The tricky part is knowing when a rescan has already been completed and the volume size on sysfs is final. The rescan may already have happened before this method is called due to an AER message or we may need to trigger it here.
Scans can be triggered manually with ‘nvme ns-rescan’ or writing 1 in configf’s rescan file, or they can be triggered indirectly when calling the ‘nvme list’, ‘nvme id-ns’, or even using the ‘nvme admin-passthru’ command.
Even after getting the new size with any of the NVMe commands above, we still need to wait until this is reflected on the host device, because we cannot return to the caller until the new size is in effect.
If we don’t see the new size taking effect on the system after 5 seconds, or if we cannot get the new size with nvme, then we rescan in the latter and in both cases we blindly wait 5 seconds and return whatever size is present.
For replicated volumes, the RAID needs to be extended.
- get_volume_paths(connection_properties: os_brick.initiator.connectors.nvmeof.NVMeOFConnProps, device_info: Optional[dict[str, str]] = None) list[str] ¶
Return paths where the volume is present.
- classmethod get_connector_properties(root_helper, *args, **kwargs) dict ¶
The NVMe-oF connector properties (initiator uuid and nqn.)