The cinder.volume.drivers.netapp.eseries.library
Module¶
-
class
NetAppESeriesLibrary
(*args, **kwargs)¶ Bases:
object
Executes commands relating to Volumes.
-
AUTOSUPPORT_INTERVAL_SECONDS
= 3600¶
-
DA_UQ_SPEC
= 'netapp_eseries_data_assurance'¶
-
DEFAULT_CHAP_USER_NAME
= 'eserieschapuser'¶
-
DEFAULT_HOST_TYPE
= 'linux_dm_mp'¶
-
DISK_TYPE_UQ_SPEC
= 'netapp_disk_type'¶
-
DRIVER_NAME
= 'NetApp_iSCSI_ESeries'¶
-
ENCRYPTION_UQ_SPEC
= 'netapp_disk_encryption'¶
-
FLASH_CACHE_UQ_SPEC
= 'netapp_eseries_flash_read_cache'¶
-
HOST_TYPES
= {'windows_clustered': 'W2KNETCL', 'linux_pathmanager': 'LnxTPGSALUA_PM', 'windows_atto': 'WinTPGSALUA', 'ontap': 'ONTAP_ALUA', 'linux_mpp_rdac': 'LNX', 'vmware': 'VmwTPGSALUA', 'windows': 'W2KNETNCL', 'linux_atto': 'LnxTPGSALUA', 'linux_sf': 'LnxTPGSALUA_SF', 'linux_dm_mp': 'LnxALUA', 'ontap_rdac': 'ONTAP_RDAC', 'factoryDefault': 'FactoryDefault'}¶
-
MAX_SNAPSHOT_COUNT
= 32¶
-
MAX_SNAPSHOT_GROUP_COUNT
= 4¶
-
RAID_UQ_SPEC
= 'netapp_raid_type'¶
-
READ_CACHE_Q_SPEC
= 'netapp:read_cache'¶
-
REQUIRED_FLAGS
= ['netapp_server_hostname', 'netapp_controller_ips', 'netapp_login', 'netapp_password']¶
-
RESERVED_SNAPSHOT_GROUP_COUNT
= 1¶
-
SA_COMM_TIMEOUT
= 30¶
-
SLEEP_SECS
= 5¶
-
SNAPSHOT_PERSISTENT_STORE_KEY
= 'cinder-snapshots'¶
-
SNAPSHOT_PERSISTENT_STORE_LOCK
= '752d02a2-0d58-4389-a044-ae0fa336feb5'¶
-
SNAPSHOT_VOL_COPY_SUFFIX
= 'SGCV'¶
-
SNAPSHOT_VOL_DEL_SUFFIX
= '_DEL'¶
-
SPINDLE_SPD_UQ_SPEC
= 'netapp_eseries_disk_spindle_speed'¶
-
SSC_DISK_TYPE_MAPPING
= {'sas': 'SAS', 'fibre': 'FCAL', 'scsi': 'SCSI', 'ssd': 'SSD', 'sata': 'SATA'}¶
-
SSC_RAID_TYPE_MAPPING
= {'raidDiskPool': 'DDP', 'raid5': 'raid5', 'raid6': 'raid6', 'raid1': 'raid1', 'raid0': 'raid0', 'raid3': 'raid5'}¶
-
SSC_UPDATE_INTERVAL
= 60¶
-
THIN_UQ_SPEC
= 'netapp_thin_provisioned'¶
-
VERSION
= '1.0.0'¶
-
WORLDWIDENAME
= 'worldWideName'¶
-
WRITE_CACHE_Q_SPEC
= 'netapp:write_cache'¶
-
check_for_setup_error
(*args, **kwargs)¶
-
create_cgsnapshot
(*args, **kwargs)¶ Creates a cgsnapshot.
-
create_cloned_volume
(*args, **kwargs)¶ Creates a clone of the specified volume.
-
create_consistencygroup
(*args, **kwargs)¶ Define a consistency group.
-
create_consistencygroup_from_src
(*args, **kwargs)¶ Define a consistency group based on an existing group
Define a new consistency group from a source consistency group. If only a source_cg is provided, then clone each base volume and add it to a new consistency group. If a cgsnapshot is provided, clone each snapshot image to a new volume and add it to the cg.
Parameters: - group – The new consistency group to define
- volumes – The volumes to add to the consistency group
- cgsnapshot – The cgsnapshot to base the group on
- snapshots – The list of snapshots on the source cg
- source_cg – The source consistency group
- source_vols – The volumes added to the source cg
-
create_export
(*args, **kwargs)¶ Exports the volume.
-
create_snapshot
(*args, **kwargs)¶ Creates a snapshot.
Parameters: - snapshot – The Cinder snapshot
- group_name – An optional label for the snapshot group
Returns: An E-Series snapshot image
-
create_volume
(*args, **kwargs)¶ Creates a volume.
-
create_volume_from_snapshot
(*args, **kwargs)¶ Creates a volume from a snapshot.
-
delete_cgsnapshot
(*args, **kwargs)¶ Deletes a cgsnapshot.
-
delete_consistencygroup
(*args, **kwargs)¶ Deletes a consistency group.
-
delete_snapshot
(*args, **kwargs)¶ Delete a snapshot.
-
delete_volume
(*args, **kwargs)¶ Deletes a volume.
-
do_setup
(*args, **kwargs)¶ Any initialization the volume driver does while starting.
-
ensure_export
(*args, **kwargs)¶ Synchronously recreates an export for a volume.
-
extend_volume
(*args, **kwargs)¶ Extend an existing volume to the new size.
-
get_pool
(*args, **kwargs)¶ Return pool name where volume resides.
Parameters: volume – The volume hosted by the driver. Returns: Name of the pool where given volume is hosted.
-
get_volume_stats
(*args, **kwargs)¶ Return the current state of the volume service.
-
initialize_connection_fc
(*args, **kwargs)¶ Initializes the connection and returns connection info.
Assigns the specified volume to a compute node/host so that it can be used from that host.
The driver returns a driver_volume_type of ‘fibre_channel’. The target_wwn can be a single entry or a list of wwns that correspond to the list of remote wwn(s) that will export the volume. Example return values:
{ 'driver_volume_type': 'fibre_channel' 'data': { 'target_discovered': True, 'target_lun': 1, 'target_wwn': '500a098280feeba5', 'initiator_target_map': { '21000024ff406cc3': ['500a098280feeba5'], '21000024ff406cc2': ['500a098280feeba5'] } } }
or
{ 'driver_volume_type': 'fibre_channel' 'data': { 'target_discovered': True, 'target_lun': 1, 'target_wwn': ['500a098280feeba5', '500a098290feeba5', '500a098190feeba5', '500a098180feeba5'], 'initiator_target_map': { '21000024ff406cc3': ['500a098280feeba5', '500a098290feeba5'], '21000024ff406cc2': ['500a098190feeba5', '500a098180feeba5'] } } }
-
initialize_connection_iscsi
(*args, **kwargs)¶ Allow connection to connector and return connection info.
-
manage_existing
(*args, **kwargs)¶ Brings an existing storage object under Cinder management.
-
manage_existing_get_size
(*args, **kwargs)¶ Return size of volume to be managed by manage_existing.
When calculating the size, round up to the next GB.
-
map_volume_to_host
(*args, **kwargs)¶ Ensures the specified initiator has access to the volume.
-
remove_export
(*args, **kwargs)¶ Removes an export for a volume.
-
terminate_connection_fc
(*args, **kwargs)¶ Disallow connection from connector.
Return empty data if other volumes are in the same zone. The FibreChannel ZoneManager doesn’t remove zones if there isn’t an initiator_target_map in the return of terminate_connection.
Returns: data - the target_wwns and initiator_target_map if the zone is to be removed, otherwise the same map with an empty dict for the ‘data’ key
-
terminate_connection_iscsi
(*args, **kwargs)¶ Disallow connection from connector.
-
unmanage
(*args, **kwargs)¶ Removes the specified volume from Cinder management.
Does not delete the underlying backend storage object. Logs a message to indicate the volume is no longer under Cinder’s control.
-
update_consistencygroup
(*args, **kwargs)¶ Add or remove volumes from an existing consistency group
-