HPE 3PAR Driver for OpenStack Manila

The HPE 3PAR driver provides NFS and CIFS shared file systems to OpenStack using HPE 3PAR’s File Persona capabilities.

For information on HPE 3PAR Driver for OpenStack Manila, refer to content kit page.

HPE 3PAR File Persona Software Suite concepts and terminology

The software suite comprises the following managed objects:

  • File Provisioning Groups (FPGs)

  • Virtual File Servers (VFSs)

  • File Stores

  • File Shares

The File Persona Software Suite is built upon the resilient mesh-active architecture of HPE 3PAR StoreServ and benefits from HPE 3PAR storage foundation of wide-striped logical disks and autonomic Common Provisioning Groups (CPGs). A CPG can be shared between file and block to create the File Shares or the logical unit numbers (LUNs) to provide true convergence.

A File Provisioning Group (FPG) is an instance of the HPE intellectual property Adaptive File System. It controls how files are stored and retrieved. Each FPG is transparently constructed from one or multiple Virtual Volumes (VVs) and is the unit for replication and disaster recovery for File Persona Software Suite. There are up to 16 FPGs supported on a node pair.

A Virtual File Server (VFS) is conceptually like a server. As such, it presents virtual IP addresses to clients, participates in user authentication services, and can have properties for such things as user/group quota management and antivirus policies. Up to 16 VFSs are supported on a node pair, one per FPG.

File Stores are the slice of a VFS and FPG at which snapshots are taken, capacity quota management can be performed, and antivirus scan service policies customized. There are up to 256 File Stores supported on a node pair, 16 File Stores per VFS.

File Shares are what provide data access to clients via SMB, NFS, and the Object Access API, subject to the share permissions applied to them. Multiple File Shares can be created for a File Store and at different directory levels within a File Store.

Supported shared filesystems

The driver supports CIFS and NFS shares.

Operations supported

  • Create a share.

    – Share is not accessible until access rules allow access.

  • Delete a share.

  • Allow share access.

    Note the following limitations:

    – IP access rules are required for NFS share access.

    – User access rules are not allowed for NFS shares.

    – User access rules are required for SMB share access.

    – User access requires a File Persona local user for SMB shares.

    – Shares are read/write (and subject to ACLs).

  • Deny share access.

  • Create a snapshot.

  • Delete a snapshot.

  • Create a share from a snapshot.

  • Extend a share.

  • Shrink a share.

  • Share networks.

HPE 3PAR File Persona driver can be configured to work with or without share networks. When using share networks, the HPE 3PAR driver allocates an FSIP on the back end FPG (VFS) to match the share network’s subnet and segmentation ID. Security groups associated with share networks are ignored.

Operations not supported

  • Manage and unmanage

  • Manila Experimental APIs (consistency groups, replication, and migration) were added in Mitaka but have not yet been implemented by the HPE 3PAR File Persona driver.

Requirements

On the OpenStack host running the Manila share service:

  • python-3parclient version 4.2.0 or newer from PyPI.

On the HPE 3PAR array:

  • HPE 3PAR Operating System software version 3.2.1 MU3 or higher.

  • The array class and hardware configuration must support File Persona.

Pre-configuration on the HPE 3PAR StoreServ

The following HPE 3PAR CLI commands show how to set up the HPE 3PAR StoreServ to use File Persona with OpenStack Manila. HPE 3PAR File Persona must be initialized, and started on the HPE 3PAR storage.

cli% startfs 0:2:1 1:2:1
cli% setfs nodeip -ipaddress 10.10.10.11 -subnet 255.255.240.0 0
cli% setfs nodeip -ipaddress 10.10.10.12 -subnet 255.255.240.0 1
cli% setfs dns 192.168.8.80,127.127.5.50 foo.com,bar.com
cli% setfs gw 10.10.10.10
  • A File Provisioning Group (FPG) must be created for use with the Shared File Systems service.

    cli% createfpg examplecpg examplefpg 18T
    
  • A Virtual File Server (VFS) must be created on the FPG.

  • The VFS must be configured with an appropriate share export IP address.

    cli% createvfs -fpg examplefpg 10.10.10.101 255.255.0.0 examplevfs
    
  • A local user in the Administrators group is needed for CIFS (SMB) shares.

    cli% createfsgroup fsusers
    cli% createfsuser –passwd <password> -enable true -grplist
    Users,Administrators –primarygroup fsusers fsadmin
    
  • The WSAPI with HTTP and/or HTTPS must be enabled and started.

    cli% setwsapi -https enable
    cli% startwsapi
    

HPE 3PAR shared file system driver configuration

  • Install the python-3parclient python package on the OpenStack Block Storage system:

    $ pip install 'python-3parclient>=4.0,<5.0'
    
  • Manila configuration file

    The Manila configuration file (typically /etc/manila/manila.conf) defines and configures the Manila drivers and backends. After updating the configuration file, the Manila share service must be restarted for changes to take effect.

  • Enable share protocols

    To enable share protocols, an optional list of supported protocols can be specified using the enabled_share_protocols setting in the DEFAULT section of the manila.conf file. The default is NFS, CIFS which allows both protocols supported by HPE 3PAR (NFS and SMB). Where Manila uses the term CIFS, HPE 3PAR uses the term SMB. Use the enabled_share_protocols option if you want to only provide one type of share (for example, only NFS) or if you want to explicitly avoid the introduction of other protocols that can be added for other drivers in the future.

  • Enable share back ends

    In the [DEFAULT] section of the Manila configuration file, use the enabled_share_backends option to specify the name of one or more back-end configuration sections to be enabled. To enable multiple back ends, use a comma-separated list.

    Note

    The name of the backend’s configuration section is used (which may be different from the share_backend_name value)

  • Configure each back end

    For each back end, a configuration section defines the driver and back end options. These include common Manila options, as well as driver-specific options. The following Driver options section describes the parameters that need to be configured in the Manila configuration file for the HPE 3PAR driver.

Driver options

The following table contains the configuration options specific to the share driver.

Description of HPE 3PAR share driver configuration options

Configuration option = Default value

Description

[DEFAULT]

hpe3par_api_url =

(String) 3PAR WSAPI Server Url like https://<3par ip>:8080/api/v1

hpe3par_cifs_admin_access_domain = LOCAL_CLUSTER

(String) File system domain for the CIFS admin user.

hpe3par_cifs_admin_access_password =

(String) File system admin password for CIFS.

hpe3par_cifs_admin_access_username =

(String) File system admin user name for CIFS.

hpe3par_debug = False

(Boolean) Enable HTTP debugging to 3PAR

hpe3par_fpg = None

(Unknown) The File Provisioning Group (FPG) to use

hpe3par_fstore_per_share = False

(Boolean) Use one filestore per share

hpe3par_password =

(String) 3PAR password for the user specified in hpe3par_username

hpe3par_require_cifs_ip = False

(Boolean) Require IP access rules for CIFS (in addition to user)

hpe3par_san_ip =

(String) IP address of SAN controller

hpe3par_san_login =

(String) Username for SAN controller

hpe3par_san_password =

(String) Password for SAN controller

hpe3par_san_ssh_port = 22

(Port number) SSH port to use with SAN

hpe3par_share_mount_path = /mnt/

(String) The path where shares will be mounted when deleting nested file trees.

hpe3par_username =

(String) 3PAR username with the ‘edit’ role

HPE 3PAR Manila driver configuration example

The following parameters shows a sample subset of the manila.conf file, which configures two backends and the relevant [DEFAULT] options. A real configuration would include additional [DEFAULT] options and additional sections that are not discussed in this document. In this example, the backends are using different FPGs on the same array:

[DEFAULT]
enabled_share_backends = HPE1,HPE2
enabled_share_protocols = NFS,CIFS
default_share_type = default
[HPE1]
share_backend_name = HPE3PAR1
share_driver = manila.share.drivers.hpe.hpe_3par_driver.HPE3ParShareDriver
driver_handles_share_servers = False
max_over_subscription_ratio = 1
hpe3par_fpg = examplefpg,10.10.10.101
hpe3par_san_ip = 10.20.30.40
hpe3par_api_url = https://10.20.30.40:8080/api/v1
hpe3par_username = <username>
hpe3par_password = <password>
hpe3par_san_login = <san_username>
hpe3par_san_password = <san_password>
hpe3par_debug = False
hpe3par_cifs_admin_access_username = <fs_admin>
hpe3par_cifs_admin_access_password = <fs_password>
[HPE2]
share_backend_name = HPE3PAR2
share_driver = manila.share.drivers.hpe.hpe_3par_driver.HPE3ParShareDriver
driver_handles_share_servers = False
max_over_subscription_ratio = 1
hpe3par_fpg = examplefpg2,10.10.10.102
hpe3par_san_ip = 10.20.30.40
hpe3par_api_url = https://10.20.30.40:8080/api/v1
hpe3par_username = <username>
hpe3par_password = <password>
hpe3par_san_login = <san_username>
hpe3par_san_password = <san_password>
hpe3par_debug = False
hpe3par_cifs_admin_access_username = <fs_admin>
hpe3par_cifs_admin_access_password = <password>

Network approach

Network connectivity between the storage array (SSH/CLI and WSAPI) and the Manila host is required for share management. Network connectivity between the clients and the VFS is required for mounting and using the shares. This includes:

  • Routing from the client to the external network.

  • Assigning the client an external IP address, for example a floating IP.

  • Configuring the Shared File Systems service host networking properly for IP forwarding.

  • Configuring the VFS networking properly for client subnets.

  • Configuring network segmentation, if applicable.

In the OpenStack Kilo release, the HPE 3PAR driver did not support share networks. Share access from clients to HPE 3PAR shares required external network access (external to OpenStack) and was set up and configured outside of Manila.

In the OpenStack Liberty release, the HPE 3PAR driver could run with or without share networks. The configuration option driver_handles_share_servers``( ``True or False ) indicated whether share networks could be used. When set to False, the HPE 3PAR driver behaved as described earlier for Kilo. When set to True, the share network’s subnet, segmentation ID and IP address range were used to allocate an FSIP on the HPE 3PAR. There is a limit of four FSIPs per VFS. For clients to communicate with shares via this FSIP, the client must have access to the external network using the subnet and segmentation ID of the share network.

For example, the client must be routed to the neutron provider network with external access. The Manila host networking configuration and network switches must support the subnet routing. If the VLAN segmentation ID is used, communication with the share will use the FSIP IP address. Neutron networking is required for HPE 3PAR share network support. Flat and VLAN provider networks are supported, but the HPE 3PAR driver does not support share network security groups.

Share access

A share that is mounted before access is allowed can appear to be an empty read-only share. After granting access, the share must be remounted.

  • IP access rules are required for NFS.

  • SMB shares require user access rules.

With the proper access rules, share access is not limited to the OpenStack environment. Access rules added via Manila or directly in HPE 3PAR CLI can be used to allow access to clients outside of the stack. The HPE 3PAR VFS/FSIP settings determine the subnets visible for HPE 3PAR share access.

  • IP access rules

    To allow IP access to a share in the horizon UI, find the share in the Project|Manage Compute|Shares view. Use the Manage Rules action to add a rule. Select IP as the access type, and enter the external IP address (for example, the floating IP) of the client in the Access to box.

    You can also use the command line to allow IP access to a share in the horizon UI with the command:

    $ manila access-allow <share-id> ip <ip-address>
    
  • User access rules

    To allow user access to a share in the horizon UI, find the share in the Project|Manage Compute|Shares view. Use the Manage Rules action to add a rule. Select user as the access type and enter user name in the Access to box.

    You can also use the command line to allow user access to a share in the horizon UI with the command:

    $ manila access-allow <share-id> user <user name>
    

    The user name must be an HPE 3PAR user.

    Share access is different from file system permissions, for example, ACLs on files and folders. If a user wants to read a file, the user must have at least read permissions on the share and an ACL that grants him read permissions on the file or folder. Even with full control share access, it does not mean every user can do everything due to the additional restrictions of the folder ACLs.

    To modify the file or folder ACLs, allow access to an HPE 3PAR File Persona local user that is in the administrator’s group and connect to the share using that user’s credentials. Then, use the appropriate mechanism to modify the ACL or permissions to allow different access than what is provided by default.

Share types

When creating a share, a share type can be specified to determine where and how the share will be created. If a share type is not specified, the default_share_type set in the Shared File Systems service configuration file is used.

Manila share types are a type or label that can be selected at share creation time in OpenStack. These types can be created either in the Admin horizon UI or using the command line, as follows:

$ manila --os-username admin --os-tenant-name demo type-create
–is_public false <name> false

The <name> is the name of the new share type. False at the end specifies driver_handles_share_servers=False. The driver_handles_share_servers setting in the share type needs to match the setting configured for the back end in the manila.conf file.

is_public is used to indicate whether this share type is applicable to all tenants or will be assigned to specific tenants.

--os-username admin --os-tenant-name demo are only needed if your environment variables do not specify the desired user and tenant.

For share types that are not public, use Manila type-access-add to assign the share type to a tenant.

  • Using share types to require share networks

    The Shared File Systems service requires that the share type include the driver_handles_share_servers extra-spec. This ensures that the share is created on a back end that supports the requested driver_handles_share_servers (share networks) capability. From the Liberty release forward, both True and False are supported.

    The driver_handles_share_servers setting in the share type must match the setting in the back end configuration.

  • Using share types to select backends by name

    Administrators can optionally specify that a particular share type be explicitly associated with a single back end (or group of backends) by including the extra spec share_backend_name to match the name specified within the share_backend_name option in the back end configuration.

    When a share type is not selected during share creation, the default share type is used. To prevent creating these shares on any back end, the default share type needs to be specific enough to find appropriate default backends (or to find none if the default should not be used). The following example shows how to set share_backend_name for a share type.

    $ manila --os-username admin --os-tenant-name demo type-key <share-type>
    set share_backend_name=HPE3PAR2
    
  • Using share types to select backends with capabilities

    The HPE 3PAR driver automatically reports capabilities based on the FPG used for each back end. An administrator can create share types with extra specs, which controls share types that can use FPGs with or without specific capabilities.

    With the OpenStack Liberty release or later, below section shows the extra specs used with the capabilities filter and the HPE 3PAR driver:

    hpe3par_flash_cache

    When the value is set to <is> True (or <is> False), shares of this type are only created on a back end that uses HPE 3PAR Adaptive Flash Cache. For Adaptive Flash Cache, the HPE 3PAR StoreServ Storage array must meet the following requirements:

    • Adaptive Flash Cache enabled

    • Available SSDs

    • Adaptive Flash Cache must be enabled on the HPE 3PAR StoreServ Storage array. This is done with the following CLI command:

      cli% createflashcache <size>
      

      <size> must be in 16 GB increments. For example, the below command creates 128 GB of Flash Cache for each node pair in the array.

      cli% createflashcache 128g
      
    • Adaptive Flash Cache must be enabled for the VV set used by an FPG. For example, setflashcache vvset:<fpgname>. The VV set name is the same as the FPG name.

      Note

      This setting affects all shares in that FPG (on that back end).

    Dedupe

    When the value is set to <is> True (or <is> False), shares of this type are only created on a back end that uses deduplication. For HPE 3PAR File Persona, the provisioning type is determined when the FPG is created. Using the createfpg –tdvv option creates an FPG that supports both dedupe and thin provisioning. The thin deduplication must be enabled to use the tdvv option.

    thin_provisioning

    When the value is set to <is> True (or <is> False), shares of this type are only created on a back end that uses thin (or full) provisioning. For HPE 3PAR File Persona, the provisioning type is determined when the FPG is created. By default, FPGs are created with thin provisioning. The capacity filter uses the total provisioned space and configured max_oversubscription_ratio when filtering and weighing backends that use thin provisioning.

  • Using share types to influence share creation options

    Scoped extra-specs are used to influence vendor-specific implementation details. Scoped extra-specs use a prefix followed by a colon. For HPE 3PAR, these extra specs have a prefix of hpe3par.

    The following HPE 3PAR extra-specs are used when creating CIFS (SMB) shares:

    hpe3par:smb_access_based_enum

    smb_access_based_enum (Access Based Enumeration) specifies if users can see only the files and directories to which they have been allowed access on the shares. Valid values are True or False. The default is False.

    hpe3par:smb_continuous_avail

    smb_continuous_avail (Continuous Availability) specifies if continuous availability features of SMB3 should be enabled for this share. Valid values are True or False. The default is True.

    hpe3par:smb_cache

    smb_cache specifies client-side caching for offline files. The default value is manual. Valid values are:

    • off — the client must not cache any files from this share. The share is configured to disallow caching.

    • manual — the client must allow only manual caching for the files open from this share.

    • optimized — the client may cache every file that it opens from this share. Also, the client may satisfy the file requests from its local cache. The share is configured to allow automatic caching of programs and documents.

    • auto — the client may cache every file that it opens from this share. The share is configured to allow automatic caching of documents.

    When creating NFS shares, the following HPE 3PAR extra-specs are used:

    hpe3par:nfs_options

    Comma separated list of NFS export options.

    The NFS export options have the following limitations:

    ro and rw are not allowed (will be determined by the driver)

    no_subtree_check and fsid are not allowed per HPE 3PAR CLI support

    (in)secure and (no_)root_squash are not allowed because the HPE 3PAR driver controls those settings

    All other NFS options are forwarded to the HPE 3PAR as part of share creation. The HPE 3PAR performs additional validation at share creation time. For details, see the HPE 3PAR CLI help.

Implementation characteristics

  • Shares from snapshots

    • When a share is created from a snapshot, the share must be deleted before the snapshot can be deleted. This is enforced by the driver.

    • A snapshot of an empty share will appear to work correctly, but attempting to create a share from an empty share snapshot may fail with an NFS Create export error.

    • HPE 3PAR File Persona snapshots are for an entire File Store. In Manila, they appear as snapshots of shares. A share sub-directory is used to give the appearance of a share snapshot when using create share from snapshot .

  • Snapshots

    • For HPE 3PAR File Persona, snapshots are per File Store and not per share. So, the HPE 3PAR limit of 1024 snapshots per File Store results in a Manila limit of 1024 snapshots per tenant on each back end FPG.

    • Before deleting a share, you must delete its snapshots. This is enforced by Manila. For HPE 3PAR File Persona, this also kicks off a snapshot reclamation.

  • Size enforcement

    Manila users create shares with size limits. HPE 3PAR enforces size limits by using File Store quotas. When using hpe3par_fstore_per_share``= ``True``(the non-default setting) there is only one share per File Store, so the size enforcement acts as expected. When using ``hpe3par_fstore_per_share = False (the default), the HPE 3PAR Manila driver uses one File Store for multiple shares. In this case, the size of the File Store limit is set to the cumulative limit of its Manila share sizes. This can allow one tenant share to exceed the limit and affect the space available for the same tenant’s other shares. One tenant cannot use another tenant’s File Store.

  • File removal

    When shares are removed and the hpe3par_fstore_per_share``=``False setting is used (the default), files may be left behind in the File Store. Prior to Mitaka, removal of obsolete share directories and files that have been stranded would require tools outside of OpenStack/Manila. In Mitaka and later, the driver mounts the File Store to remove the deleted share’s subdirectory and files. For SMB/CIFS share, it requires the hpe3par_cifs_admin_access_username and hpe3par_cifs_admin_access_password configuration. If the mount and delete cannot be performed, an error is logged and the share is deleted in Manila. Due to the potential space held by leftover files, File Store quotas are not reduced when shares are removed.

  • Multi-tenancy

    • Network

      The driver_handles_share_servers configuration setting determines whether share networks are supported. When driver_handles_share_servers is set to True, a share network is required to create a share. The administrator creates share networks with the desired network, subnet, IP range, and segmentation ID. The HPE 3PAR is configured with an FSIP using the same subnet and segmentation ID and an IP address allocated from the neutron network. Using share network-specific IP addresses, subnets, and segmentation IDs give the appearance of better tenant isolation. Shares on an FPG, however, are accessible via any of the FSIPs (subject to access rules). Back end filtering should be used for further separation.

    • Back end filtering

      A Manila HPE 3PAR back end configuration refers to a specific array and a specific FPG. With multiple backends and multiple tenants, the scheduler determines where shares will be created. In a scenario where an array or back end needs to be restricted to one or more specific tenants, share types can be used to influence the selection of a back end. For more information on using share types, see Share types .

    • Tenant limit

      The HPE 3PAR driver uses one File Store per tenant per protocol in each configured FPG. When only one back end is configured, this results in a limit of eight tenants (16 if only using one protocol). Use multiple back end configurations to introduce additional FPGs on the same array to increase the tenant limit.

      When using share networks, an FSIP is created for each share network (when its first share is created on the back end). The HPE 3PAR supports 4 FSIPs per FPG (VFS). One of those 4 FSIPs is reserved for the initial VFS IP, so the share network limit is 48 share networks per node pair.