Skip to content

Latest commit

 

History

History
496 lines (284 loc) · 11.9 KB

device.rst

File metadata and controls

496 lines (284 loc) · 11.9 KB

device -- Manage device on Dell PowerFlex

Managing device on PowerFlex storage system includes adding new device, getting details of device, and removing a device.

The below requirements are needed on the host that executes this module.

  • A Dell PowerFlex storage system version 3.6 or later.
  • PyPowerFlex 1.14.0.
current_pathname (optional, str, None)

Full path of the device to be added.

Required while adding a device.

device_name (optional, str, None)

Device name.

Mutually exclusive with device_id.

device_id (optional, str, None)

Device ID.

Mutually exclusive with device_name.

sds_name (optional, str, None)

The name of the SDS.

Required while adding a device.

Mutually exclusive with sds_id.

sds_id (optional, str, None)

The ID of the SDS.

Required while adding a device.

Mutually exclusive with sds_name.

storage_pool_name (optional, str, None)

Storage Pool name.

Used while adding a storage device.

Mutually exclusive with storage_pool_id, acceleration_pool_id and acceleration_pool_name.

storage_pool_id (optional, str, None)

Storage Pool ID.

Used while adding a storage device.

Media type supported are SSD and HDD.

Mutually exclusive with storage_pool_name, acceleration_pool_id and acceleration_pool_name.

acceleration_pool_name (optional, str, None)

Acceleration Pool Name.

Used while adding an acceleration device.

Media type supported are SSD and NVDIMM.

Mutually exclusive with storage_pool_id, storage_pool_name and acceleration_pool_name.

acceleration_pool_id (optional, str, None)

Acceleration Pool ID.

Used while adding an acceleration device.

Media type supported are SSD and NVDIMM.

Mutually exclusive with acceleration_pool_name, storage_pool_name and storage_pool_id.

protection_domain_name (optional, str, None)

Protection domain name.

Used while identifying a storage pool along with storage_pool_name.

Mutually exclusive with protection_domain_id.

protection_domain_id (optional, str, None)

Protection domain ID.

Used while identifying a storage pool along with storage_pool_name.

Mutually exclusive with protection_domain_name.

external_acceleration_type (optional, str, None)

Device external acceleration types.

Used while adding a device.

media_type (optional, str, None)

Device media types.

Required while adding a device.

state (True, str, None)
State of the device.
force (optional, bool, False)

Using the Force flag to add a device.

Use this flag, to overwrite existing data on the device.

Use this flag with caution, because all data on the device will be destroyed.

hostname (True, str, None)
IP or FQDN of the PowerFlex host.
username (True, str, None)
The username of the PowerFlex host.
password (True, str, None)
The password of the PowerFlex host.
validate_certs (optional, bool, True)

Boolean variable to specify whether or not to validate SSL certificate.

true - Indicates that the SSL certificate should be verified.

false - Indicates that the SSL certificate should not be verified.

port (optional, int, 443)
Port number through which communication happens with PowerFlex host.
timeout (False, int, 120)

Time after which connection will get terminated.

It is to be mentioned in seconds.

Note

  • The value for device_id is generated only after successful addition of the device.
  • To uniquely identify a device, either device_id can be passed or one of current_pathname or device_name must be passed with sds_id or sds_name.
  • It is recommended to install Rfcache driver for SSD device on SDS in order to add it to an acceleration pool.
  • The check_mode is not supported.
  • The modules present in the collection named as 'dellemc.powerflex' are built to support the Dell PowerFlex storage platform.
- name: Add a device
  dellemc.powerflex.device:
    hostname: "{{hostname}}"
    username: "{{username}}"
    password: "{{password}}"
    validate_certs: "{{validate_certs}}"
    port: "{{port}}"
    current_pathname: "/dev/sdb"
    sds_name: "node1"
    media_type: "HDD"
    device_name: "device2"
    storage_pool_name: "pool1"
    protection_domain_name: "domain1"
    external_acceleration_type: "ReadAndWrite"
    state: "present"
- name: Add a device with force flag
  dellemc.powerflex.device:
    hostname: "{{hostname}}"
    username: "{{username}}"
    password: "{{password}}"
    validate_certs: "{{validate_certs}}"
    port: "{{port}}"
    current_pathname: "/dev/sdb"
    sds_name: "node1"
    media_type: "HDD"
    device_name: "device2"
    storage_pool_name: "pool1"
    protection_domain_name: "domain1"
    external_acceleration_type: "ReadAndWrite"
    force: true
    state: "present"
- name: Get device details using device_id
  dellemc.powerflex.device:
    hostname: "{{hostname}}"
    username: "{{username}}"
    password: "{{password}}"
    validate_certs: "{{validate_certs}}"
    port: "{{port}}"
    device_id: "d7fe088900000000"
    state: "present"
- name: Get device details using (current_pathname, sds_name)
  dellemc.powerflex.device:
    hostname: "{{hostname}}"
    username: "{{username}}"
    password: "{{password}}"
    validate_certs: "{{validate_certs}}"
    port: "{{port}}"
    current_pathname: "/dev/sdb"
    sds_name: "node0"
    state: "present"
- name: Get device details using (current_pathname, sds_id)
  dellemc.powerflex.device:
    hostname: "{{hostname}}"
    username: "{{username}}"
    password: "{{password}}"
    validate_certs: "{{validate_certs}}"
    port: "{{port}}"
    current_pathname: "/dev/sdb"
    sds_id: "5717d71800000000"
    state: "present"
- name: Remove a device using device_id
  dellemc.powerflex.device:
    hostname: "{{hostname}}"
    username: "{{username}}"
    password: "{{password}}"
    validate_certs: "{{validate_certs}}"
    port: "{{port}}"
    device_id: "76eb7e2f00010000"
    state: "absent"
- name: Remove a device using (current_pathname, sds_id)
  dellemc.powerflex.device:
    hostname: "{{hostname}}"
    username: "{{username}}"
    password: "{{password}}"
    validate_certs: "{{validate_certs}}"
    port: "{{port}}"
    current_pathname: "/dev/sdb"
    sds_name: "node1"
    state: "absent"
changed (always, bool, false)
Whether or not the resource has changed.
device_details (When device exists, dict, {'accelerationPoolId': None, 'accelerationProps': None, 'aggregatedState': 'NeverFailed', 'ataSecurityActive': False, 'autoDetectMediaType': 'SSD', 'cacheLookAheadActive': False, 'capacity': 0, 'capacityLimitInKb': 365772800, 'deviceCurrentPathName': '/dev/sdb', 'deviceOriginalPathName': '/dev/sdb', 'deviceState': 'Normal', 'deviceType': 'Unknown', 'errorState': 'None', 'externalAccelerationType': 'None', 'fglNvdimmMetadataAmortizationX100': 150, 'fglNvdimmWriteCacheSize': 16, 'firmwareVersion': None, 'id': 'b6efa59900000000', 'ledSetting': 'Off', 'links': [{'href': '/api/instances/Device::b6efa59900000000', 'rel': 'self'}, {'href': '/api/instances/Device::b6efa59900000000/relationships /Statistics', 'rel': '/api/Device/relationship/Statistics'}, {'href': '/api/instances/Sds::8f3bb0ce00000000', 'rel': '/api/parent/relationship/sdsId'}, {'href': '/api/instances/StoragePool::e0d8f6c900000000', 'rel': '/api/parent/relationship/storagePoolId'}, {'href': '/api/instances/SpSds::fedf6f2000000000', 'rel': '/api/parent/relationship/spSdsId'}], 'logicalSectorSizeInBytes': 0, 'longSuccessfulIos': {'longWindow': None, 'mediumWindow': None, 'shortWindow': None}, 'maxCapacityInKb': 365772800, 'mediaFailing': False, 'mediaType': 'HDD', 'modelName': None, 'name': 'device230', 'persistentChecksumState': 'Protected', 'physicalSectorSizeInBytes': 0, 'protectionDomainId': '9300c1f900000000', 'protectionDomainName': 'domain1', 'raidControllerSerialNumber': None, 'rfcacheErrorDeviceDoesNotExist': False, 'rfcacheProps': None, 'sdsId': '8f3bb0ce00000000', 'sdsName': 'node1', 'serialNumber': None, 'slotNumber': None, 'spSdsId': 'fedf6f2000000000', 'ssdEndOfLifeState': 'NeverFailed', 'storagePoolId': 'e0d8f6c900000000', 'storagePoolName': 'pool1', 'storageProps': {'destFglAccDeviceId': None, 'destFglNvdimmSizeMb': 0, 'fglAccDeviceId': None, 'fglNvdimmSizeMb': 0}, 'temperatureState': 'NeverFailed', 'vendorName': None, 'writeCacheActive': False})

Details of the device.

accelerationPoolId (, str, )
Acceleration pool ID.
accelerationPoolName (, str, )
Acceleration pool name.
accelerationProps (, str, )
Indicates acceleration props.
aggregatedState (, str, )
Indicates aggregated state.
ataSecurityActive (, bool, )
Indicates ATA security active state.
autoDetectMediaType (, str, )
Indicates auto detection of media type.
cacheLookAheadActive (, bool, )
Indicates cache look ahead active state.
capacity (, int, )
Device capacity.
capacityLimitInKb (, int, )
Device capacity limit in KB.
deviceCurrentPathName (, str, )
Device current path name.
deviceOriginalPathName (, str, )
Device original path name.
deviceState (, str, )
Indicates device state.
deviceType (, str, )
Indicates device type.
errorState (, str, )
Indicates error state.
externalAccelerationType (, str, )
Indicates external acceleration type.
fglNvdimmMetadataAmortizationX100 (, int, )
Indicates FGL NVDIMM meta data amortization value.
fglNvdimmWriteCacheSize (, int, )
Indicates FGL NVDIMM write cache size.
firmwareVersion (, str, )
Indicates firmware version.
id (, str, )
Device ID.
ledSetting (, str, )
Indicates LED setting.
links (, list, )

Device links.

href (, str, )
Device instance URL.
rel (, str, )
Relationship of device with different entities.
logicalSectorSizeInBytes (, int, )
Logical sector size in bytes.
longSuccessfulIos (, list, )
Indicates long successful IOs.
maxCapacityInKb (, int, )
Maximum device capacity limit in KB.
mediaFailing (, bool, )
Indicates media failing.
mediaType (, str, )
Indicates media type.
modelName (, str, )
Indicates model name.
name (, str, )
Device name.
persistentChecksumState (, str, )
Indicates persistent checksum state.
physicalSectorSizeInBytes (, int, )
Physical sector size in bytes.
protectionDomainId (, str, )
Protection domain ID.
protectionDomainName (, str, )
Protection domain name.
raidControllerSerialNumber (, str, )
RAID controller serial number.
rfcacheErrorDeviceDoesNotExist (, bool, )
Indicates RF cache error device does not exist.
rfcacheProps (, str, )
RF cache props.
sdsId (, str, )
SDS ID.
sdsName (, str, )
SDS name.
serialNumber (, str, )
Indicates Serial number.
spSdsId (, str, )
Indicates SPs SDS ID.
ssdEndOfLifeState (, str, )
Indicates SSD end of life state.
storagePoolId (, str, )
Storage Pool ID.
storagePoolName (, str, )
Storage Pool name.
storageProps (, list, )
Storage props.
temperatureState (, str, )
Indicates temperature state.
vendorName (, str, )
Indicates vendor name.
writeCacheActive (, bool, )
Indicates write cache active.

Authors