Fix documentation for types and extra specs
Some content in the admin docs was incomplete, and irrelevant to administrators. Also add notes on a couple of missing common capabilities: - mount_snapshot_support - availability_zones Partial-Bug: #1816486 Change-Id: Ie55fd5bf80ca2ebacdb652c701aa9c213f758963 Signed-off-by: Goutham Pacha Ravi <gouthampravi@gmail.com>
This commit is contained in:
		| @@ -2,44 +2,96 @@ | |||||||
|  |  | ||||||
| Capabilities and Extra-Specs | Capabilities and Extra-Specs | ||||||
| ============================ | ============================ | ||||||
| Manila Administrators create share types with extra-specs to allow users | Cloud Administrators create :ref:`shared_file_systems_share_types` with | ||||||
| to request a type of share to create. The Administrator chooses a name | extra-specs to: | ||||||
| for the share type and decides how to communicate the significance of |  | ||||||
| the different share types in terms that the users should understand or |  | ||||||
| need to know. By design, most of the details of a share type (the extra- |  | ||||||
| specs) are not exposed to users -- only Administrators. |  | ||||||
|  |  | ||||||
| Share Types | - influence the scheduler's decision to place new shares, and | ||||||
| ----------- | - instruct the Shared File System service or its storage driver/s to perform | ||||||
| Refer to the manila client command-line help for information on how to |   certain special actions with respect to the users' shares. | ||||||
| create a share type and set "extra-spec" key/value pairs for a share type. |  | ||||||
|  |  | ||||||
| Extra-Specs | As an administrator, you can choose a descriptive name or provide good | ||||||
| ----------- | descriptions for your share types to convey the share type capabilities to | ||||||
| There are 3 types of extra-specs: required, scoped, and un-scoped. | end users. End users can view standard ``tenant-visible`` extra-specs that | ||||||
|  | can let them seek required behavior and automate their applications | ||||||
|  | accordingly. By design, however, all other extra-specs of a share type are not | ||||||
|  | exposed to non-privileged users. | ||||||
|  |  | ||||||
| Manila *requires* the driver_handles_share_servers extra-spec. | Types of Extra-Specs | ||||||
|  | -------------------- | ||||||
|  |  | ||||||
| *Scoped* extra-specs use a prefix followed by a colon to define a namespace | The Shared File Systems service back-end storage drivers offer a wide range of | ||||||
| for scoping the extra-spec. A prefix could be a vendor name or acronym | capabilities. The variation in these capabilities allows cloud | ||||||
| and is a hint that this extra-spec key/value only applies to that vendor's | administrators to provide a storage service catalog to their end users. | ||||||
| driver. Scoped extra-specs are not used by the scheduler to determine | Share type extra-specs tie-in with these capabilities. | ||||||
| where a share is created (except for the special `capabilities` prefix). |  | ||||||
| It is up to each driver implementation to determine how to use scoped |  | ||||||
| extra-specs and to document them. |  | ||||||
|  |  | ||||||
| The prefix "capabilities" is a special prefix to indicate extra-specs that | Some back-end capabilities are very specific to a storage system, and are | ||||||
| are treated like un-scoped extra-specs. In the CapabilitiesFilter the | opaque to the Shared File System service or the end users. These | ||||||
| "capabilities:" is stripped from the key and then the extra-spec key and | capabilities are invoked with the help of "scoped" extra-specs. Using scoped | ||||||
| value are used as an un-scoped extra-spec. | extra-specs is a way to provide programmatic directives to the concerned | ||||||
|  | storage driver to do something during share creation or share manipulation. | ||||||
|  | You can learn about the opaque capabilities through driver documentation | ||||||
|  | and configure these capabilities within share types as scoped | ||||||
|  | extra-specs (e.g.: hpe3par:nfs_options). The Shared File System service | ||||||
|  | scheduler ignores scoped extra-specs during its quest to find the right back | ||||||
|  | end to provision shares. | ||||||
|  |  | ||||||
| *Un-scoped* extra-specs have a key that either starts with "capabilities:" or | There are some back-end capabilities in manila that do matter to the scheduler. | ||||||
| does not contain a colon. When the CapabilitiesFilter is enabled (it is | For our understanding, lets call these non-scoped or non-opaque capabilities. | ||||||
| enabled by default), the scheduler will only create a share on a backend | All non-scoped capabilities can be directly used as share types extra-specs. | ||||||
| that reports capabilities that match the share type's un-scoped extra-spec | They are considered by the scheduler’s capabilities filter (and any custom | ||||||
| keys. | filter defined by deployers). | ||||||
|  |  | ||||||
| The CapabilitiesFilter uses the following for matching operators: | You can get a list of non-scoped capabilities from the scheduler by using: | ||||||
|  |  | ||||||
|  | .. code-block:: console | ||||||
|  |  | ||||||
|  |     $ manila pool-list --detail | ||||||
|  |  | ||||||
|  | The non-scoped capabilities can be of three types: | ||||||
|  |  | ||||||
|  | - **Capabilities pertaining to a specific back end storage system driver**: For | ||||||
|  |   example, *huawei_smartcache*. | ||||||
|  |   No Shared File System service API relies on non-opaque back end specific | ||||||
|  |   capabilities. | ||||||
|  | - **Common capabilities that are not visible to end users**: The manila | ||||||
|  |   community has standardized some cross-platform capabilities like | ||||||
|  |   *thin_provisioning*, *dedupe*, *compression*, *qos*, *ipv6_support* and | ||||||
|  |   *ipv4_support*. Values of these options do not matter to any Shared File | ||||||
|  |   System service APIs; however, they can signify something to the manila | ||||||
|  |   services themselves. For example when a back end supports thin_provisioning, | ||||||
|  |   the scheduler service performs over-provisioning, and if a back end does | ||||||
|  |   not report *ipv6_support* as True, the share-manager service drops IPv6 | ||||||
|  |   access rules before invoking the storage driver to update access rules. | ||||||
|  | - **Common capabilities that are visible to end users**: Some capabilities | ||||||
|  |   affect functionality exposed via the Shared File System service API. For | ||||||
|  |   example, not all back ends support snapshots, and even if they do, they | ||||||
|  |   may not support all of the snapshot operations. For example, cloning | ||||||
|  |   snapshots into new shares, reverting shares in-place to snapshots, etc. | ||||||
|  |  | ||||||
|  |   The support for these capabilities determines whether users would be able | ||||||
|  |   to perform certain control-plane operations with manila. For example, a back | ||||||
|  |   end driver may report *snapshot_support=True* allowing end users to | ||||||
|  |   create share snapshots, however, the driver can report | ||||||
|  |   *create_share_from_snapshot_support=False*. | ||||||
|  |   This reporting allows cloud administrators to create share types that | ||||||
|  |   support snapshots but not creating shares from snapshots. When a user uses | ||||||
|  |   such a share type, they will not be able to clone snapshots into new shares. | ||||||
|  |   Tenant-visible capabilities aid manila in validating requests and failing | ||||||
|  |   fast on requests it cannot accommodate. They also help level set the user | ||||||
|  |   expectations on some failures. For example, if snapshot_support is set to | ||||||
|  |   False on the share type, since users can see this, they will not invoke | ||||||
|  |   the create snapshot API, and even if they do, they will understand the | ||||||
|  |   HTTP 400 (and error message) in better context. | ||||||
|  |  | ||||||
|  | .. important:: | ||||||
|  |  | ||||||
|  |     All extra-specs are optional, except one: *driver_handles_share_servers*. | ||||||
|  |  | ||||||
|  | Scheduler's treatment of non-scoped extra specs | ||||||
|  | ----------------------------------------------- | ||||||
|  |  | ||||||
|  | The CapabilitiesFilter in the Shared File System scheduler uses the following | ||||||
|  | for matching operators: | ||||||
|  |  | ||||||
| * No operator | * No operator | ||||||
|   This defaults to doing a python ==. Additionally it will match boolean values. |   This defaults to doing a python ==. Additionally it will match boolean values. | ||||||
| @@ -74,63 +126,107 @@ The CapabilitiesFilter uses the following for matching operators: | |||||||
|  |  | ||||||
| * **s==, s!=, s>=, s>, s<=, s<** | * **s==, s!=, s>=, s>, s<=, s<** | ||||||
|  |  | ||||||
|   The "s" indicates it is a string comparison. These choose a host that satisfies |   The "s" indicates it is a string comparison. These choose a host that | ||||||
|   the comparison of strings in capability and specification. For example, |   satisfies the comparison of strings in capability and specification. For | ||||||
|   if "capabilities:replication_type s== dr", a host that reports |   example, if "capabilities:replication_type s== dr", a host that reports | ||||||
|   replication_type of "dr" will be chosen. |   replication_type of "dr" will be chosen. If "share_backend_name s!= | ||||||
|  |   cephfs" is used, any host not named "cephfs" can be chosen. | ||||||
|  |  | ||||||
| For vendor-specific capabilities (which need to be visible to the | For vendor-specific non-scoped capabilities (which need to be visible to the | ||||||
| CapabilityFilter), it is recommended to use the vendor prefix followed | scheduler), drivers are recommended to use the vendor prefix followed | ||||||
| by an underscore. This is not a strict requirement, but will provide a | by an underscore. This is not a strict requirement, but can provide a | ||||||
| consistent look along-side the scoped extra-specs and will be a clear | consistent look along-side the scoped extra-specs and will be a clear | ||||||
| indicator of vendor capabilities vs. common capabilities. | indicator of vendor capabilities vs. common capabilities. | ||||||
|  |  | ||||||
| Common Capabilities | Common Capabilities | ||||||
| ------------------- | ------------------- | ||||||
| For capabilities that apply to multiple backends a common capability can | Common capabilities apply to multiple backends. | ||||||
| be created. Like all other backend reported capabilities, these capabilities | Like all other backend reported capabilities, these capabilities | ||||||
| can be used verbatim as extra_specs in share types used to create shares. | can be used verbatim as extra_specs in share types used to create shares. | ||||||
|  |  | ||||||
| * `driver_handles_share_servers` is a special, required, user-visible common | Share type common capability extra-specs that are visible to end users: | ||||||
|   capability. Added in Kilo. | ----------------------------------------------------------------------- | ||||||
|  |  | ||||||
| * `dedupe` - indicates that a backend/pool can provide shares using some | * **driver_handles_share_servers** is a special, required common | ||||||
|  |   capability. When set to True, the scheduler matches requests with back ends | ||||||
|  |   that can isolate user workloads with dedicated share servers exporting | ||||||
|  |   shares on user provided share networks. | ||||||
|  |  | ||||||
|  | * **snapshot_support** indicates whether snapshots are supported for shares | ||||||
|  |   created on the pool/backend. When administrators do not set this capability | ||||||
|  |   as an extra-spec in a share type, the scheduler can place new shares of that | ||||||
|  |   type in pools without regard for whether snapshots are supported, and those | ||||||
|  |   shares will not support snapshots. | ||||||
|  |  | ||||||
|  | * **create_share_from_snapshot_support** indicates whether a backend can | ||||||
|  |   create a new share from a snapshot. When administrators do not set this | ||||||
|  |   capability as an extra-spec in a share type, the scheduler can place new | ||||||
|  |   shares of that type in pools without regard for whether creating shares | ||||||
|  |   from snapshots is supported, and those shares will not support creating | ||||||
|  |   shares from snapshots. | ||||||
|  |  | ||||||
|  | * **revert_to_snapshot_support** indicates that a driver is capable of | ||||||
|  |   reverting a share in place to its most recent snapshot. When administrators | ||||||
|  |   do not set this capability as an extra-spec in a share type, the scheduler | ||||||
|  |   can place new shares of that type in pools without regard for whether | ||||||
|  |   reverting shares to snapshots is supported, and those shares will not support | ||||||
|  |   reverting shares to snapshots. | ||||||
|  |  | ||||||
|  | * **mount_snapshot_support** indicates that a driver is capable of exporting | ||||||
|  |   share snapshots for mounting. Users can provide and revoke access to | ||||||
|  |   mountable snapshots just like they can with their shares. | ||||||
|  |  | ||||||
|  | * **replication_type** indicates the style of replication supported for the | ||||||
|  |   backend/pool. This extra_spec will have a string value and could be one | ||||||
|  |   of :term:`writable`, :term:`readable` or :term:`dr`. `writable` replication | ||||||
|  |   type involves synchronously replicated shares where all replicas are | ||||||
|  |   writable. Promotion is not supported and not needed. `readable` and `dr` | ||||||
|  |   replication types involve a single `active` or `primary` replica and one or | ||||||
|  |   more `non-active` or secondary replicas per share. In `readable` type of | ||||||
|  |   replication, `non-active` replicas have one or more export_locations and | ||||||
|  |   can thus be mounted and read while the `active` replica is the only one | ||||||
|  |   that can be written into. In `dr` style of replication, only | ||||||
|  |   the `active` replica can be mounted, read from and written into. | ||||||
|  |  | ||||||
|  | * **availability_zones** indicates a comma separated list of availability | ||||||
|  |   zones that can be used for provisioning. Users can always provide a specific | ||||||
|  |   availability zone during share creation, and they will receive a | ||||||
|  |   synchronous failure message if they attempt to create a share in an | ||||||
|  |   availability zone that the share type does not permit. If you do not set | ||||||
|  |   this extra-spec, the share type is assumed to be serviceable in all | ||||||
|  |   availability zones known to the Shared File Systems service. | ||||||
|  |  | ||||||
|  | Share type common capability extra-specs that are not visible to end users: | ||||||
|  | --------------------------------------------------------------------------- | ||||||
|  |  | ||||||
|  | * **dedupe** indicates that a backend/pool can provide shares using some | ||||||
|   deduplication technology. The default value of the dedupe capability (if a |   deduplication technology. The default value of the dedupe capability (if a | ||||||
|   driver doesn't report it) is False. In Liberty, drivers cannot report to the |   driver doesn't report it) is False. Drivers can support both dedupe and | ||||||
|   scheduler that they support both dedupe and non-deduped share. For each pool |   non-deduped shares in a single storage pool by reporting ``dedupe=[True, | ||||||
|   it's either always on or always off, even if the drivers can technically |   False]``. You can make a share type use deduplication by setting this | ||||||
|   support both dedupe and non-deduped in a pool. Since Mitaka, the logic is |   extra-spec to '<is> True', or prevent it by setting this extra-spec | ||||||
|   changed to allow a driver to report dedupe=[True, False] if it can support |   to '<is> False'. | ||||||
|   both dedupe and non-deduped in a pool. Administrators can make a share type |  | ||||||
|   use deduplication by setting this extra-spec to '<is> True'. Administrators |  | ||||||
|   can prevent a share type from using deduplication by setting this extra-spec |  | ||||||
|   to '<is> False'. Added in Liberty. |  | ||||||
|  |  | ||||||
| * `compression` - indicates that a backend/pool can provide shares using some | * **compression** indicates that a backend/pool can provide shares using some | ||||||
|   compression technology. The default value of the compression capability (if a |   compression technology. The default value of the compression capability (if a | ||||||
|   driver doesn't report it) is False. In Liberty, drivers cannot report to the |   driver doesn't report it) is False. Drivers can support compressed and | ||||||
|   scheduler that they support both compression and non-compression. For each |   non-compressed shares in a single storage pool by reporting | ||||||
|   pool it's either always on or always off, even if the drivers can technically |   ``compression=[True, False]``. You can make a share type use compression | ||||||
|   support both compression and non-compression in a pool. Since Mitaka, the |   by setting this extra-spec to '<is> True', or prevent it by setting this | ||||||
|   logic is changed to allow a driver to report compression=[True, False] if it |   extra-spec to '<is> False'. | ||||||
|   can support both compression and non-compression in a pool. Administrators |  | ||||||
|   can make a share type use compression by setting this extra-spec to |  | ||||||
|   '<is> True'. Administrators can prevent a share type from using compression |  | ||||||
|   by setting this extra-spec to '<is> False'. Added in Liberty. |  | ||||||
|  |  | ||||||
| * `thin_provisioning` - shares will not be space guaranteed and | * **thin_provisioning** can be enabled where shares will not be | ||||||
|   overprovisioning will be enabled. This capability defaults to False. |   guaranteed space allocations and overprovisioning will be enabled. This | ||||||
|   Backends/pools that support thin provisioning must report True for this |   capability defaults to False. Back ends/pools that support thin | ||||||
|   capability. Administrators can make a share type use thin provisioned shares |   provisioning report True for this capability. Administrators can make a | ||||||
|   by setting this extra-spec to '<is> True'. If a driver reports |   share type use thin provisioned shares by setting this extra-spec | ||||||
|   thin_provisioning=False (the default) then it's assumed that the driver is |   to '<is> True'. If a driver reports thin_provisioning=False (the default) | ||||||
|   doing thick provisioning and overprovisioning is turned off. |   then it's assumed that the driver is doing thick provisioning and | ||||||
|   This was added in Liberty. In Liberty and Mitaka, the driver was required |   overprovisioning is turned off. A driver can support thin provisioned | ||||||
|   to configure one pool for thin and another pool for thick and report |   and thick provisioned shares in the same pool by reporting | ||||||
|   thin_provisioning as either True or False even if an array can technically |   ``thin_provisioning=[True, False]``. | ||||||
|   support both thin and thick provisioning in a pool. In Newton, the logic is |  | ||||||
|   changed to allow a driver to report thin_provisioning=[True, False] if it |   To provision a thick | ||||||
|   can support both thin and thick provisioning in a pool. To provision a thick |  | ||||||
|   share on a back end that supports both thin and thick provisioning, set one |   share on a back end that supports both thin and thick provisioning, set one | ||||||
|   of the following in extra specs: |   of the following in extra specs: | ||||||
|  |  | ||||||
| @@ -141,154 +237,23 @@ can be used verbatim as extra_specs in share types used to create shares. | |||||||
|     {'capabilities:thin_provisioning': 'False'} |     {'capabilities:thin_provisioning': 'False'} | ||||||
|     {'capabilities:thin_provisioning': '<is> False'} |     {'capabilities:thin_provisioning': '<is> False'} | ||||||
|  |  | ||||||
| * `qos` - indicates that a backend/pool can provide shares using some | * **qos** indicates that a backend/pool can provide shares using some | ||||||
|   QoS (Quality of Service) specification. The default value of the qos |   QoS (Quality of Service) specification. The default value of the qos | ||||||
|   capability (if a driver doesn't report it) is False. Administrators |   capability (if a driver doesn't report it) is False. You can make a share | ||||||
|   can make a share type use QoS by setting this extra-spec to '<is> True' and |   type use QoS by setting this extra-spec to '<is> True' and also setting | ||||||
|   also setting the relevant QoS-related extra specs for the drivers being used. |   the relevant QoS-related extra specs for the drivers being used. | ||||||
|   Administrators can prevent a share type from using QoS by setting this |   Administrators can prevent a share type from using QoS by setting this | ||||||
|   extra-spec to '<is> False'. Different drivers have different ways of specifying |   extra-spec to '<is> False'. Different drivers have different ways of | ||||||
|   QoS limits (or guarantees) and this extra spec merely allows the scheduler to |   specifying QoS limits (or guarantees) and this extra spec merely allows | ||||||
|   filter by pools that either have or don't have QoS support enabled. Added in |   the scheduler to filter by pools that either have or don't have QoS | ||||||
|   Mitaka. |   support enabled. | ||||||
|  |  | ||||||
| * `replication_type` - indicates the style of replication supported for the | * **ipv4_support** indicates whether a back end can create a share that | ||||||
|   backend/pool. This extra_spec will have a string value and could be one |   can be accessed via IPv4 protocol. If administrators do not set this | ||||||
|   of :term:`writable`, :term:`readable` or :term:`dr`. `writable` replication |   capability as an extra-spec in a share type, the scheduler can place new | ||||||
|   type involves synchronously replicated shares where all replicas are |   shares of that type in pools without regard for whether IPv4 is supported. | ||||||
|   writable. Promotion is not supported and not needed. `readable` and `dr` |  | ||||||
|   replication types involve a single `active` or `primary` replica and one or |  | ||||||
|   more `non-active` or secondary replicas per share. In `readable` type of |  | ||||||
|   replication, `non-active` replicas have one or more export_locations and |  | ||||||
|   can thus be mounted and read while the `active` replica is the only one |  | ||||||
|   that can be written into. In `dr` style of replication, only |  | ||||||
|   the `active` replica can be mounted, read from and written into. Added in |  | ||||||
|   Mitaka. |  | ||||||
|  |  | ||||||
| * `snapshot_support` - indicates whether snapshots are supported for shares | * **ipv6_support** - indicates whether a back end can create a share that | ||||||
|   created on the pool/backend. When administrators do not set this capability |   can be accessed via IPv6 protocol. If administrators do not set this | ||||||
|   as an extra-spec in a share type, the scheduler can place new shares of that |   capability as an extra-spec in a share type, the scheduler can place new | ||||||
|   type in pools without regard for whether snapshots are supported, and those |   shares of that type in pools without regard for whether IPv6 is supported. | ||||||
|   shares will not support snapshots. |  | ||||||
|  |  | ||||||
| * `create_share_from_snapshot_support` - indicates whether a backend can create |  | ||||||
|   a new share from a snapshot. When administrators do not set this capability |  | ||||||
|   as an extra-spec in a share type, the scheduler can place new shares of that |  | ||||||
|   type in pools without regard for whether creating shares from snapshots is |  | ||||||
|   supported, and those shares will not support creating shares from snapshots. |  | ||||||
|  |  | ||||||
| * `revert_to_snapshot_support` - indicates that a driver is capable of |  | ||||||
|   reverting a share in place to its most recent snapshot. When administrators |  | ||||||
|   do not set this capability as an extra-spec in a share type, the scheduler |  | ||||||
|   can place new shares of that type in pools without regard for whether |  | ||||||
|   reverting shares to snapshots is supported, and those shares will not support |  | ||||||
|   reverting shares to snapshots. |  | ||||||
|  |  | ||||||
| * `ipv4_support` - indicates whether a back end can create a share that can be |  | ||||||
|   accessed via IPv4 protocol. If administrators do not set this capability |  | ||||||
|   as an extra-spec in a share type, the scheduler can place new shares of that |  | ||||||
|   type in pools without regard for whether IPv4 is supported. |  | ||||||
|  |  | ||||||
| * `ipv6_support` - indicates whether a back end can create a share that can be |  | ||||||
|   accessed via IPv6 protocol. If administrators do not set this capability |  | ||||||
|   as an extra-spec in a share type, the scheduler can place new shares of that |  | ||||||
|   type in pools without regard for whether IPv6 is supported. |  | ||||||
|  |  | ||||||
| Reporting Capabilities |  | ||||||
| ---------------------- |  | ||||||
| Drivers report capabilities as part of the updated stats (e.g. capacity) |  | ||||||
| for their backend/pools. This is how a backend/pool advertizes its ability |  | ||||||
| to provide a share that matches the capabilities requested in the share |  | ||||||
| type extra-specs. |  | ||||||
|  |  | ||||||
| Developer impact |  | ||||||
| ---------------- |  | ||||||
|  |  | ||||||
| Developers should update their drivers to include all backend and pool |  | ||||||
| capacities and capabilities in the share stats it reports to scheduler. |  | ||||||
| Below is an example having multiple pools. "my" is used as an |  | ||||||
| example vendor prefix: |  | ||||||
|  |  | ||||||
| :: |  | ||||||
|  |  | ||||||
|     { |  | ||||||
|         'driver_handles_share_servers': 'False',  #\ |  | ||||||
|         'share_backend_name': 'My Backend',       # backend level |  | ||||||
|         'vendor_name': 'MY',                      # mandatory/fixed |  | ||||||
|         'driver_version': '1.0',                  # stats & capabilities |  | ||||||
|         'storage_protocol': 'NFS_CIFS',           #/ |  | ||||||
|                                                   #\ |  | ||||||
|         'my_capability_1': 'custom_val',          # "my" optional vendor |  | ||||||
|         'my_capability_2': True,                  # stats & capabilities |  | ||||||
|                                                   #/ |  | ||||||
|         'pools': [ |  | ||||||
|             {'pool_name': |  | ||||||
|                'thin-dedupe-compression pool',    #\ |  | ||||||
|              'total_capacity_gb': 500,            #  mandatory stats for |  | ||||||
|              'free_capacity_gb': 230,             #  pools |  | ||||||
|              'reserved_percentage': 0,            #/ |  | ||||||
|                                                   #\ |  | ||||||
|              'dedupe': True,                      # common capabilities |  | ||||||
|              'compression': True,                 # |  | ||||||
|              'snapshot_support': True,            # |  | ||||||
|              'create_share_from_snapshot_support': True, |  | ||||||
|              'revert_to_snapshot_support': True, |  | ||||||
|              'qos': True,                         # this backend supports QoS |  | ||||||
|              'thin_provisioning': True,           # |  | ||||||
|              'max_over_subscription_ratio': 10,   # (mandatory for thin) |  | ||||||
|              'provisioned_capacity_gb': 270,      # (mandatory for thin) |  | ||||||
|                                                   # |  | ||||||
|                                                   # |  | ||||||
|              'replication_type': 'dr',            # this backend supports |  | ||||||
|                                                   # replication_type 'dr' |  | ||||||
|                                                   #/ |  | ||||||
|              'my_dying_disks': 100,               #\ |  | ||||||
|              'my_super_hero_1': 'Hulk',           #  "my" optional vendor |  | ||||||
|              'my_super_hero_2': 'Spider-Man',     #  stats & capabilities |  | ||||||
|                                                   #/ |  | ||||||
|                                                   #\ |  | ||||||
|                                                   # can replicate to other |  | ||||||
|              'replication_domain': 'asgard',      # backends in |  | ||||||
|                                                   # replication_domain 'asgard' |  | ||||||
|                                                   #/ |  | ||||||
|              'ipv4_support': True, |  | ||||||
|              'ipv6_support': True, |  | ||||||
|  |  | ||||||
|             }, |  | ||||||
|             {'pool_name': 'thick pool', |  | ||||||
|              'total_capacity_gb': 1024, |  | ||||||
|              'free_capacity_gb': 1024, |  | ||||||
|              'qos': False, |  | ||||||
|              'snapshot_support': True, |  | ||||||
|              'create_share_from_snapshot_support': False, # this pool does not |  | ||||||
|                                                           # allow creating |  | ||||||
|                                                           # shares from |  | ||||||
|                                                           # snapshots |  | ||||||
|              'revert_to_snapshot_support': True, |  | ||||||
|              'reserved_percentage': 0, |  | ||||||
|              'dedupe': False, |  | ||||||
|              'compression': False, |  | ||||||
|              'thin_provisioning': False, |  | ||||||
|              'replication_type': None, |  | ||||||
|              'my_dying_disks': 200, |  | ||||||
|              'my_super_hero_1': 'Batman', |  | ||||||
|              'my_super_hero_2': 'Robin', |  | ||||||
|              'ipv4_support': True, |  | ||||||
|              'ipv6_support': True, |  | ||||||
|             }, |  | ||||||
|          ] |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| Work Flow |  | ||||||
| --------- |  | ||||||
|  |  | ||||||
| 1) Share Backends report how many pools and what those pools look like and |  | ||||||
|    are capable of to scheduler; |  | ||||||
|  |  | ||||||
| 2) When request comes in, scheduler picks a pool that fits the need best to |  | ||||||
|    serve the request, it passes the request to the backend where the target |  | ||||||
|    pool resides; |  | ||||||
|  |  | ||||||
| 3) Share driver gets the message and lets the target pool serve the request |  | ||||||
|    as scheduler instructed. Share type extra-specs (scoped and un-scoped) |  | ||||||
|    are available for the driver implementation to use as-needed. |  | ||||||
|   | |||||||
| @@ -2,9 +2,8 @@ | |||||||
|  |  | ||||||
| Group Capabilities and group-specs | Group Capabilities and group-specs | ||||||
| ================================== | ================================== | ||||||
| Manila Administrators create share group types with `share types | Manila Administrators create share group types with | ||||||
| <https://docs.openstack.org/manila/latest/admin/ | :ref:`shared_file_systems_share_types` and group-specs to allow users | ||||||
| shared-file-systems-share-types.html>`_ and group-specs to allow users |  | ||||||
| to request a group type of share group to create. The Administrator chooses | to request a group type of share group to create. The Administrator chooses | ||||||
| a name for the share group type and decides how to communicate the significance | a name for the share group type and decides how to communicate the significance | ||||||
| of the different share group types in terms that the users should understand or | of the different share group types in terms that the users should understand or | ||||||
| @@ -40,56 +39,3 @@ create share groups. | |||||||
|   The default value of the consistent_snapshot_support capability (if a |   The default value of the consistent_snapshot_support capability (if a | ||||||
|   driver doesn't report it) is None. Administrators can make a share group |   driver doesn't report it) is None. Administrators can make a share group | ||||||
|   type use consistent snapshot support by setting this group-spec to 'host'. |   type use consistent snapshot support by setting this group-spec to 'host'. | ||||||
|  |  | ||||||
| Reporting Group Capabilities |  | ||||||
| ---------------------------- |  | ||||||
| Drivers report group capabilities as part of the updated stats (e.g. capacity) |  | ||||||
| and filled in 'share_group_stats' node for their back end. This is how a backend |  | ||||||
| advertizes its ability to provide a share that matches the group capabilities |  | ||||||
| requested in the share group type group-specs. |  | ||||||
|  |  | ||||||
| Developer impact |  | ||||||
| ---------------- |  | ||||||
|  |  | ||||||
| Developers should update their drivers to include all backend and pool |  | ||||||
| capacities and capabilities in the share stats it reports to scheduler. |  | ||||||
| Below is an example having multiple pools. "my" is used as an |  | ||||||
| example vendor prefix: |  | ||||||
|  |  | ||||||
| :: |  | ||||||
|  |  | ||||||
|     { |  | ||||||
|         'driver_handles_share_servers': 'False',          #\ |  | ||||||
|         'share_backend_name': 'My Backend',               # backend level |  | ||||||
|         'vendor_name': 'MY',                              # mandatory/fixed |  | ||||||
|         'driver_version': '1.0',                          # stats & capabilities |  | ||||||
|         'storage_protocol': 'NFS_CIFS',                   #/ |  | ||||||
|                                                           #\ |  | ||||||
|         'my_capability_1': 'custom_val',                  # "my" optional vendor |  | ||||||
|         'my_capability_2': True,                          # stats & capabilities |  | ||||||
|                                                           #/ |  | ||||||
|         'share_group_stats': { |  | ||||||
|                                                           #\ |  | ||||||
|                 'my_group_capability_1': 'custom_val',    # "my" optional vendor |  | ||||||
|                 'my_group_capability_2': True,            # stats & group capabilities |  | ||||||
|                                                           #/ |  | ||||||
|                 'consistent_snapshot_support': 'host',    #\ |  | ||||||
|                                                           # common group capabilities |  | ||||||
|                                                           #/ |  | ||||||
|             }, |  | ||||||
|          ] |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| Work Flow |  | ||||||
| --------- |  | ||||||
|  |  | ||||||
| 1) Share Backends report how many pools and what those pools look like and |  | ||||||
|    are capable of to group scheduler; |  | ||||||
|  |  | ||||||
| 2) When request comes in, scheduler picks a backend that fits the need best to |  | ||||||
|    serve the request, it passes the request to the backend where the target |  | ||||||
|    pool resides; |  | ||||||
|  |  | ||||||
| 3) Share driver gets the message and lets the target pool serve the request |  | ||||||
|    as group scheduler instructed. Share group type group-specs (scoped and un-scoped) |  | ||||||
|    are available for the driver implementation to use as-needed. |  | ||||||
|   | |||||||
| @@ -45,11 +45,11 @@ deployment. | |||||||
|  |  | ||||||
|    shared-file-systems-key-concepts.rst |    shared-file-systems-key-concepts.rst | ||||||
|    shared-file-systems-share-management.rst |    shared-file-systems-share-management.rst | ||||||
|    shared-file-systems-share-server-management.rst |  | ||||||
|    shared-file-systems-share-migration.rst |  | ||||||
|    shared-file-systems-share-types.rst |    shared-file-systems-share-types.rst | ||||||
|    shared-file-systems-snapshots.rst |    shared-file-systems-snapshots.rst | ||||||
|  |    shared-file-systems-share-server-management.rst | ||||||
|    shared-file-systems-security-services.rst |    shared-file-systems-security-services.rst | ||||||
|  |    shared-file-systems-share-migration.rst | ||||||
|    shared-file-systems-share-replication.rst |    shared-file-systems-share-replication.rst | ||||||
|    shared-file-systems-multi-backend.rst |    shared-file-systems-multi-backend.rst | ||||||
|    shared-file-systems-networking.rst |    shared-file-systems-networking.rst | ||||||
|   | |||||||
| @@ -4,136 +4,218 @@ | |||||||
| Share types | Share types | ||||||
| =========== | =========== | ||||||
|  |  | ||||||
| A share type enables you to filter or choose back ends before you create a | The Shared File System service back-end storage drivers offer a wide range | ||||||
| share and to set data for the share driver. A share type behaves in the same | of capabilities. The variation in these capabilities allows cloud | ||||||
| way as a Block Storage volume type behaves. | administrators to provide a storage service catalog to their end users. | ||||||
|  | Share types can be used to create this storage service catalog. | ||||||
|  | Cloud administrators can influence provisioning of users' shares with the | ||||||
|  | help of Share types. All shares are associated with a share type. Share | ||||||
|  | types are akin to ``flavors`` in the OpenStack Compute service (nova), or | ||||||
|  | ``volume types`` in the OpenStack Block Storage service (cinder), or ``storage | ||||||
|  | classes`` in Kubernetes. You can allow a share type to be accessible to all | ||||||
|  | users in your cloud if you wish. You can also create private share types that | ||||||
|  | allow only users belonging to certain OpenStack projects to access them. | ||||||
|  | You can have an unlimited number of share types in your | ||||||
|  | cloud, but for practical purposes, you may want to create only a handful of | ||||||
|  | publicly accessible share types. | ||||||
|  |  | ||||||
| In the Shared File Systems configuration file ``manila.conf``, the | Each share type is an object that encompasses ``extra-specs`` (extra | ||||||
| administrator can set the share type used by default for the share creation | specifications). These extra-specs can map to storage back-end capabilities, | ||||||
| and then create a default share type. | or can be directives to the service. | ||||||
|  |  | ||||||
| To create a share type, use :command:`manila type-create` command as: | Consider for example, offering three share types in your cloud to map | ||||||
|  | to "service levels": | ||||||
|  |  | ||||||
|  | +--------+--------------------------------------------------------------------------------------------------+ | ||||||
|  | |  Type  |                                    Capabilities/Instructions                                     | | ||||||
|  | +========+==================================================================================================+ | ||||||
|  | | Gold   | Allow creating snapshots, reverting to snapshots and share replication, "thick" provision shares | | ||||||
|  | +--------+--------------------------------------------------------------------------------------------------+ | ||||||
|  | | Silver | Allow creating snapshots, "thin" provision shares                                                | | ||||||
|  | +--------+--------------------------------------------------------------------------------------------------+ | ||||||
|  | | Bronze | Don't allow creating snapshots, "thin" provision shares                                          | | ||||||
|  | +--------+--------------------------------------------------------------------------------------------------+ | ||||||
|  |  | ||||||
|  | Capabilities or instructions such as the ones above are coded as extra-specs | ||||||
|  | that your users and the Shared File System service understand. Users in | ||||||
|  | OpenStack projects can see all public share types along with private share | ||||||
|  | types that are made accessible to them. Not all extra-specs that you | ||||||
|  | configure in a share type are visible to your users. This design helps | ||||||
|  | preserve the cloud abstraction. Along with the share type names, they can | ||||||
|  | see the share type descriptions and "tenant-visible" extra-specs. | ||||||
|  |  | ||||||
|  | For more details on extra-specs, see :ref:`capabilities_and_extra_specs`. | ||||||
|  |  | ||||||
|  | The Shared File Systems service also allows using quota controls with share | ||||||
|  | types. Quotas can help you maintain your SLAs by limiting the number of | ||||||
|  | consumable resources or aid in billing. See :ref:`shared_file_systems_quotas` | ||||||
|  | for more details. | ||||||
|  |  | ||||||
|  | Driver Handles Share Servers (DHSS) | ||||||
|  | ----------------------------------- | ||||||
|  |  | ||||||
|  | To provide secure and hard multi-tenancy on the network data path, the | ||||||
|  | Shared File Systems service allows users to use their own "share networks". | ||||||
|  | When shares are created on a share network, users can be sure they have | ||||||
|  | their own isolated "share servers" that export their shares on the share | ||||||
|  | network that have the ability plug into user-determined authentication | ||||||
|  | domains ("security services"). Not all Shared File System service storage | ||||||
|  | drivers support share networks. Those that do assert the capability | ||||||
|  | ``driver_handles_share_servers=True``. | ||||||
|  |  | ||||||
|  | When creating a share type, you are *required* to set an extra-spec that | ||||||
|  | matches this capability. It is visible to end users. | ||||||
|  |  | ||||||
|  | Default Share Type | ||||||
|  | ------------------ | ||||||
|  |  | ||||||
|  | When you are operating a cloud where all your tenants are trusted, you may | ||||||
|  | want to create a "default" share type that applies to all of them. It | ||||||
|  | simplifies share creation for your end users since they don't need to worry | ||||||
|  | about share types. | ||||||
|  |  | ||||||
|  | Use of a default share type is not recommended in a multi-tenant cloud where | ||||||
|  | you may want to separate your user workloads, or offer different service | ||||||
|  | capabilities. In such instances, you must always encourage your users to | ||||||
|  | specify a share type at share creation time, and not rely on the default | ||||||
|  | share type. | ||||||
|  |  | ||||||
|  | .. important:: | ||||||
|  |  | ||||||
|  |     If you do not create and configure a default share type, users *must* | ||||||
|  |     specify a valid share type during share creation, or share creation | ||||||
|  |     requests will fail. | ||||||
|  |  | ||||||
|  | To configure the default share type, edit the ``manila.conf`` file, and set | ||||||
|  | the configuration option [DEFAULT]/default_share_type. | ||||||
|  |  | ||||||
|  | You must then create a share type, using :command:`manila type-create`: | ||||||
|  |  | ||||||
| .. code-block:: console | .. code-block:: console | ||||||
|  |  | ||||||
|    manila type-create [--snapshot_support <snapshot_support>] |    manila type-create [--is_public <is_public>] | ||||||
|                       [--is_public <is_public>] |                       [--description <description>] | ||||||
|  |                       [--extra-specs <other-extra-specs>] | ||||||
|                       <name> <spec_driver_handles_share_servers> |                       <name> <spec_driver_handles_share_servers> | ||||||
|  |  | ||||||
| where the ``name`` is the share type name, ``--is_public`` defines the level of | where: | ||||||
| the visibility for the share type, ``snapshot_support`` and |  | ||||||
| ``spec_driver_handles_share_servers`` are the extra specifications used to |  | ||||||
| filter back ends. Administrators can create share types with these extra |  | ||||||
| specifications for the back ends filtering: |  | ||||||
|  |  | ||||||
| - ``driver_handles_share_servers``. Required. Defines the driver mode for share | - ``name`` is the share type name | ||||||
|   server lifecycle management. Valid values are ``true``/``1`` and | - ``is_public`` defines the visibility for the share type (true/false) | ||||||
|   ``false``/``0``. | - ``description`` is a free form text field to describe the characteristics | ||||||
|   Set to True when the share driver can manage, or handle, the share server |   of the share type for your users' benefit | ||||||
|   lifecycle. | - ``extra-specs`` defines a comma separated set of key=value pairs of | ||||||
|   Set to False when an administrator, rather than a share driver, manages |   optional extra specifications | ||||||
|   the bare metal storage with some net interface instead of the presence | - ``spec_driver_handles_share_servers`` is the mandatory extra-spec | ||||||
|   of the share servers. |   (true/false) | ||||||
|  |  | ||||||
| - ``snapshot_support``. Filters back ends by whether they do or do not support |  | ||||||
|   share snapshots. Default is ``True``. |  | ||||||
|   Set to True to find back ends that support share snapshots. |  | ||||||
|   Set to False to find back ends that do not support share snapshots. |  | ||||||
|  |  | ||||||
| .. note:: |  | ||||||
|  |  | ||||||
|    The extra specifications set in the share types are operated in the |  | ||||||
|    :ref:`shared_file_systems_scheduling`. |  | ||||||
|  |  | ||||||
| Administrators can also set additional extra specifications for a share type |  | ||||||
| for the following purposes: |  | ||||||
|  |  | ||||||
| - *Filter back ends*. Unqualified extra specifications written in |  | ||||||
|   this format: ``extra_spec=value``. For example, **netapp_raid_type=raid4**. |  | ||||||
|  |  | ||||||
| - *Set data for the driver*. Qualified extra specifications always written |  | ||||||
|   with the prefix with a colon, except for the special ``capabilities`` |  | ||||||
|   prefix, in this format: ``vendor:extra_spec=value``. For example, |  | ||||||
|   **netapp:thin_provisioned=true**. |  | ||||||
|  |  | ||||||
| The scheduler uses the special capabilities prefix for filtering. The scheduler |  | ||||||
| can only create a share on a back end that reports capabilities matching the |  | ||||||
| un-scoped extra-spec keys for the share type. For details, see `Capabilities |  | ||||||
| and Extra-Specs <https://docs.openstack.org/manila/latest/admin/ |  | ||||||
| capabilities_and_extra_specs.html>`_. |  | ||||||
|  |  | ||||||
| Each driver implementation determines which extra specification keys it uses. |  | ||||||
| For details, see the documentation for the driver. |  | ||||||
|  |  | ||||||
| An administrator can use the ``policy.json`` file to grant permissions for |  | ||||||
| share type creation with extra specifications to other roles. |  | ||||||
|  |  | ||||||
| You set a share type to private or public and |  | ||||||
| :ref:`manage the access<share_type_access>` to the private share types. By |  | ||||||
| default a share type is created as publicly accessible. Set |  | ||||||
| ``--is_public`` to ``False`` to make the share type private. |  | ||||||
|  |  | ||||||
| Share type operations | Share type operations | ||||||
| --------------------- | --------------------- | ||||||
|  |  | ||||||
| To create a new share type you need to specify the name of the new share | To create a new share type you need to specify the name of the new share | ||||||
| type. You also require an extra spec ``driver_handles_share_servers``. | type. You also require an extra spec ``driver_handles_share_servers``. | ||||||
| The new share type can also be public. | The new share type can be public or private. | ||||||
|  |  | ||||||
| .. code-block:: console | .. code-block:: console | ||||||
|  |  | ||||||
|    $ manila type-create netapp1 False --is_public True |    $ manila manila type-create default-shares False \ | ||||||
|  |      --description "Default share type for the cloud, no fancy capabilities" | ||||||
|  |  | ||||||
|    $ manila type-list |    $ manila type-list | ||||||
|    +-----+--------+-----------+-----------+-----------------------------------+-----------------------+ |     +--------------------------------------+-----------------------------------+------------+------------+--------------------------------------+-------------------------------------------+---------------------------------------------------------+ | ||||||
|    | ID  | Name   | Visibility| is_default| required_extra_specs              | optional_extra_specs  | |     | ID                                   | Name                              | visibility | is_default | required_extra_specs                 | optional_extra_specs                      | Description                                             | | ||||||
|    +-----+--------+-----------+-----------+-----------------------------------+-----------------------+ |     +--------------------------------------+-----------------------------------+------------+------------+--------------------------------------+-------------------------------------------+---------------------------------------------------------+ | ||||||
|    | c0..| netapp1| public    | -         | driver_handles_share_servers:False| snapshot_support:True | |     | cf1f92ec-4d0a-4b79-8f18-6bb82c22840a | default-shares                    | public     | -          | driver_handles_share_servers : False |                                           | Default share type for the cloud, no fancy capabilities | | ||||||
|    +-----+--------+-----------+-----------+-----------------------------------+-----------------------+ |     +--------------------------------------+-----------------------------------+------------+------------+--------------------------------------+-------------------------------------------+---------------------------------------------------------+ | ||||||
|  |  | ||||||
|  |     $ manila type-show default-shares | ||||||
|  |     +----------------------+---------------------------------------------------------+ | ||||||
|  |     | Property             | Value                                                   | | ||||||
|  |     +----------------------+---------------------------------------------------------+ | ||||||
|  |     | id                   | cf1f92ec-4d0a-4b79-8f18-6bb82c22840a                    | | ||||||
|  |     | name                 | default-shares                                          | | ||||||
|  |     | visibility           | public                                                  | | ||||||
|  |     | is_default           | NO                                                      | | ||||||
|  |     | description          | Default share type for the cloud, no fancy capabilities | | ||||||
|  |     | required_extra_specs | driver_handles_share_servers : False                    | | ||||||
|  |     | optional_extra_specs |                                                         | | ||||||
|  |     +----------------------+---------------------------------------------------------+ | ||||||
|  |  | ||||||
|  | You did not provide optional capabilities, so they are all *assumed to be off | ||||||
|  | by default*. So, Non-privileged users see some tenant-visible capabilities | ||||||
|  | explicitly. | ||||||
|  |  | ||||||
|  | .. code-block:: console | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     $ source demorc | ||||||
|  |     $ manila type-list | ||||||
|  |     +--------------------------------------+-----------------------------------+------------+------------+--------------------------------------+--------------------------------------------+---------------------------------------------------------+ | ||||||
|  |     | ID                                   | Name                              | visibility | is_default | required_extra_specs                 | optional_extra_specs                       | Description                                             | | ||||||
|  |     +--------------------------------------+-----------------------------------+------------+------------+--------------------------------------+--------------------------------------------+---------------------------------------------------------+ | ||||||
|  |     | cf1f92ec-4d0a-4b79-8f18-6bb82c22840a | default-shares                    | public     | -          | driver_handles_share_servers : False | snapshot_support : False                   | Default share type for the cloud, no fancy capabilities | | ||||||
|  |     +--------------------------------------+-----------------------------------+------------+------------+--------------------------------------+--------------------------------------------+---------------------------------------------------------+ | ||||||
|  |  | ||||||
|  |     $ manila type-show default-shares | ||||||
|  |     +----------------------+---------------------------------------------------------+ | ||||||
|  |     | Property             | Value                                                   | | ||||||
|  |     +----------------------+---------------------------------------------------------+ | ||||||
|  |     | id                   | cf1f92ec-4d0a-4b79-8f18-6bb82c22840a                    | | ||||||
|  |     | name                 | default-shares                                          | | ||||||
|  |     | visibility           | public                                                  | | ||||||
|  |     | is_default           | NO                                                      | | ||||||
|  |     | description          | Default share type for the cloud, no fancy capabilities | | ||||||
|  |     | required_extra_specs | driver_handles_share_servers : False                    | | ||||||
|  |     | optional_extra_specs | snapshot_support : False                                | | ||||||
|  |     |                      | create_share_from_snapshot_support : False              | | ||||||
|  |     |                      | revert_to_snapshot_support : False                      | | ||||||
|  |     |                      | mount_snapshot_support : False                          | | ||||||
|  |     +----------------------+---------------------------------------------------------+ | ||||||
|  |  | ||||||
|  |  | ||||||
| You can set or unset extra specifications for a share type | You can set or unset extra specifications for a share type | ||||||
| using **manila type-key <share_type> set <key=value>** command. Since it is up | using **manila type-key <share_type> set <key=value>** command. | ||||||
| to each driver what extra specification keys it uses, see the documentation |  | ||||||
| for the specified driver. |  | ||||||
|  |  | ||||||
| .. code-block:: console | .. code-block:: console | ||||||
|  |  | ||||||
|    $ manila type-key netapp1 set thin_provisioned=True |    $ manila type-key default-shares set snapshot_support=True | ||||||
|  |  | ||||||
| It is also possible to view a list of current share types and extra |    $ manila type-show default-shares | ||||||
| specifications: |     +----------------------+---------------------------------------------------------+ | ||||||
|  |     | Property             | Value                                                   | | ||||||
| .. code-block:: console |     +----------------------+---------------------------------------------------------+ | ||||||
|  |     | id                   | cf1f92ec-4d0a-4b79-8f18-6bb82c22840a                    | | ||||||
|    $ manila extra-specs-list |     | name                 | default-shares                                          | | ||||||
|    +-------------+---------+-------------------------------------+ |     | visibility           | public                                                  | | ||||||
|    | ID          | Name    | all_extra_specs                     | |     | is_default           | NO                                                      | | ||||||
|    +-------------+---------+-------------------------------------+ |     | description          | Default share type for the cloud, no fancy capabilities | | ||||||
|    | c0086582-...| netapp1 | snapshot_support : True             | |     | required_extra_specs | driver_handles_share_servers : False                    | | ||||||
|    |             |         | thin_provisioned : True             | |     | optional_extra_specs | snapshot_support : True                                 | | ||||||
|    |             |         | driver_handles_share_servers : True | |     +----------------------+---------------------------------------------------------+ | ||||||
|    +-------------+---------+-------------------------------------+ |  | ||||||
|  |  | ||||||
| Use :command:`manila type-key <share_type> unset <key>` to unset an extra | Use :command:`manila type-key <share_type> unset <key>` to unset an extra | ||||||
| specification. | specification. | ||||||
|  |  | ||||||
| The public or private share type can be deleted with the | A share type can be deleted with the :command:`manila type-delete | ||||||
| :command:`manila type-delete <share_type>` command. | <share_type>` command. However, a share type can only be deleted if there | ||||||
|  | are no shares, share groups or share group types associated with the share | ||||||
|  | type. | ||||||
|  |  | ||||||
| .. _share_type_access: | .. _share_type_access: | ||||||
|  |  | ||||||
| Share type access | Share type access control | ||||||
| ----------------- | ------------------------- | ||||||
|  |  | ||||||
| You can manage access to a private share type for different projects. | You can provide access, revoke access, and retrieve list of allowed projects | ||||||
| Administrators can provide access, remove access, and retrieve | for a specified private share. | ||||||
| information about access for a specified private share. |  | ||||||
|  |  | ||||||
| Create a private type: | Create a private type: | ||||||
|  |  | ||||||
| .. code-block:: console | .. code-block:: console | ||||||
|  |  | ||||||
|    $ manila type-create my_type1 True --is_public False |    $ manila type-create my_type1 True \ | ||||||
|  |             --is_public False \ | ||||||
|  |             --extra-specs snapshot_support=True | ||||||
|    +----------------------+--------------------------------------+ |    +----------------------+--------------------------------------+ | ||||||
|    | Property             | Value                                | |    | Property             | Value                                | | ||||||
|    +----------------------+--------------------------------------+ |    +----------------------+--------------------------------------+ | ||||||
| @@ -148,8 +230,7 @@ Create a private type: | |||||||
| .. note:: | .. note:: | ||||||
|  |  | ||||||
|    If you run :command:`manila type-list` only public share types appear. |    If you run :command:`manila type-list` only public share types appear. | ||||||
|    To see private share types, run :command:`manila type-list` with |    To see private share types, run :command:`manila type-list --all``. | ||||||
|    ``--all`` optional argument. |  | ||||||
|  |  | ||||||
| Grant access to created private type for a demo and alt_demo projects | Grant access to created private type for a demo and alt_demo projects | ||||||
| by providing their IDs: | by providing their IDs: | ||||||
| @@ -171,9 +252,8 @@ To view information about access for a private share, type ``my_type1``: | |||||||
|    | e4970f57f1824faab2701db61ee7efdf | |    | e4970f57f1824faab2701db61ee7efdf | | ||||||
|    +----------------------------------+ |    +----------------------------------+ | ||||||
|  |  | ||||||
| After granting access to the share, the target project | After granting access to the share, the users in the allowed projects | ||||||
| can see the share type in the list, and create private | can see the share type and use it to create shares. | ||||||
| shares. |  | ||||||
|  |  | ||||||
| To deny access for a specified project, use | To deny access for a specified project, use | ||||||
| :command:`manila type-access-remove <share_type> <project_id>` command. | :command:`manila type-access-remove <share_type> <project_id>` command. | ||||||
|   | |||||||
| @@ -14,8 +14,8 @@ | |||||||
|       License for the specific language governing permissions and limitations |       License for the specific language governing permissions and limitations | ||||||
|       under the License. |       under the License. | ||||||
|  |  | ||||||
| Manila minimum requirements and features since Mitaka | Manila minimum requirements and features | ||||||
| ===================================================== | ======================================== | ||||||
|  |  | ||||||
| In order for a driver to be accepted into manila code base, there are certain | In order for a driver to be accepted into manila code base, there are certain | ||||||
| minimum requirements and features that must be met, in order to ensure | minimum requirements and features that must be met, in order to ensure | ||||||
| @@ -74,8 +74,11 @@ Capabilities | |||||||
| ------------ | ------------ | ||||||
|  |  | ||||||
| In order for manila to function accordingly to the driver being used, the | In order for manila to function accordingly to the driver being used, the | ||||||
| driver must provide a set of information to manila, known as capabilities, as | driver must provide a set of information to manila, known as capabilities. | ||||||
| follows: | Share driver can use Share type extra-specs (scoped and un-scoped) to serve | ||||||
|  | new shares. See :doc:`../admin/capabilities_and_extra_specs` for more | ||||||
|  | information. At a minimum your driver must report: | ||||||
|  |  | ||||||
|  |  | ||||||
| - share_backend_name: a name for the backend; | - share_backend_name: a name for the backend; | ||||||
| - driver_handles_share_servers: driver mode, whether this driver instance | - driver_handles_share_servers: driver mode, whether this driver instance | ||||||
| @@ -102,7 +105,79 @@ function correctly in manila, such as: | |||||||
| - replication_type: string specifying the type of replication supported by | - replication_type: string specifying the type of replication supported by | ||||||
|   the driver. Can be one of ('readable', 'writable' or 'dr'). |   the driver. Can be one of ('readable', 'writable' or 'dr'). | ||||||
|  |  | ||||||
| .. note:: for more information please see https://docs.openstack.org/manila/latest/admin/capabilities_and_extra_specs.html | Below is an example of drivers with multiple pools. "my" is used as an | ||||||
|  | example vendor prefix: | ||||||
|  |  | ||||||
|  | :: | ||||||
|  |  | ||||||
|  |     { | ||||||
|  |         'driver_handles_share_servers': 'False',  #\ | ||||||
|  |         'share_backend_name': 'My Backend',       # backend level | ||||||
|  |         'vendor_name': 'MY',                      # mandatory/fixed | ||||||
|  |         'driver_version': '1.0',                  # stats & capabilities | ||||||
|  |         'storage_protocol': 'NFS_CIFS',           #/ | ||||||
|  |                                                   #\ | ||||||
|  |         'my_capability_1': 'custom_val',          # "my" optional vendor | ||||||
|  |         'my_capability_2': True,                  # stats & capabilities | ||||||
|  |                                                   #/ | ||||||
|  |         'pools': [ | ||||||
|  |             {'pool_name': | ||||||
|  |                'thin-dedupe-compression pool',    #\ | ||||||
|  |              'total_capacity_gb': 500,            #  mandatory stats for | ||||||
|  |              'free_capacity_gb': 230,             #  pools | ||||||
|  |              'reserved_percentage': 0,            #/ | ||||||
|  |                                                   #\ | ||||||
|  |              'dedupe': True,                      # common capabilities | ||||||
|  |              'compression': True,                 # | ||||||
|  |              'snapshot_support': True,            # | ||||||
|  |              'create_share_from_snapshot_support': True, | ||||||
|  |              'revert_to_snapshot_support': True, | ||||||
|  |              'qos': True,                         # this backend supports QoS | ||||||
|  |              'thin_provisioning': True,           # | ||||||
|  |              'max_over_subscription_ratio': 10,   # (mandatory for thin) | ||||||
|  |              'provisioned_capacity_gb': 270,      # (mandatory for thin) | ||||||
|  |                                                   # | ||||||
|  |                                                   # | ||||||
|  |              'replication_type': 'dr',            # this backend supports | ||||||
|  |                                                   # replication_type 'dr' | ||||||
|  |                                                   #/ | ||||||
|  |              'my_dying_disks': 100,               #\ | ||||||
|  |              'my_super_hero_1': 'Hulk',           #  "my" optional vendor | ||||||
|  |              'my_super_hero_2': 'Spider-Man',     #  stats & capabilities | ||||||
|  |                                                   #/ | ||||||
|  |                                                   #\ | ||||||
|  |                                                   # can replicate to other | ||||||
|  |              'replication_domain': 'asgard',      # backends in | ||||||
|  |                                                   # replication_domain 'asgard' | ||||||
|  |                                                   #/ | ||||||
|  |              'ipv4_support': True, | ||||||
|  |              'ipv6_support': True, | ||||||
|  |  | ||||||
|  |             }, | ||||||
|  |             {'pool_name': 'thick pool', | ||||||
|  |              'total_capacity_gb': 1024, | ||||||
|  |              'free_capacity_gb': 1024, | ||||||
|  |              'qos': False, | ||||||
|  |              'snapshot_support': True, | ||||||
|  |              'create_share_from_snapshot_support': False, # this pool does not | ||||||
|  |                                                           # allow creating | ||||||
|  |                                                           # shares from | ||||||
|  |                                                           # snapshots | ||||||
|  |              'revert_to_snapshot_support': True, | ||||||
|  |              'reserved_percentage': 0, | ||||||
|  |              'dedupe': False, | ||||||
|  |              'compression': False, | ||||||
|  |              'thin_provisioning': False, | ||||||
|  |              'replication_type': None, | ||||||
|  |              'my_dying_disks': 200, | ||||||
|  |              'my_super_hero_1': 'Batman', | ||||||
|  |              'my_super_hero_2': 'Robin', | ||||||
|  |              'ipv4_support': True, | ||||||
|  |              'ipv6_support': True, | ||||||
|  |             }, | ||||||
|  |          ] | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |  | ||||||
| Continuous Integration systems | Continuous Integration systems | ||||||
| ------------------------------ | ------------------------------ | ||||||
| @@ -124,7 +199,7 @@ All drivers submitted must be contemplated with unit tests covering at least | |||||||
| framework and be located in-tree using a structure that mirrors the functional | framework and be located in-tree using a structure that mirrors the functional | ||||||
| code, such as directory names and filenames. See template below: | code, such as directory names and filenames. See template below: | ||||||
|  |  | ||||||
|   :: | :: | ||||||
|  |  | ||||||
|     manila/[tests/]path/to/brand/new/[test_]driver.py |     manila/[tests/]path/to/brand/new/[test_]driver.py | ||||||
|  |  | ||||||
| @@ -206,10 +281,41 @@ additional functionalities such as consistent group snapshot, the driver | |||||||
| vendors may report this capability as a group capability, such as: Ordered | vendors may report this capability as a group capability, such as: Ordered | ||||||
| writes, Consistent snapshots, Group replication. | writes, Consistent snapshots, Group replication. | ||||||
|  |  | ||||||
|  | Drivers need to report group capabilities as part of the updated stats (e.g. | ||||||
|  | capacity) and filled in 'share_group_stats' node for their back end. Share group | ||||||
|  | type group-specs (scoped and un-scoped) are available for the driver | ||||||
|  | implementation to use as-needed. Below is an example of the share stats | ||||||
|  | payload from the driver having multiple pools and group capabilities. "my" | ||||||
|  | is used as an example vendor prefix: | ||||||
|  |  | ||||||
|  | :: | ||||||
|  |  | ||||||
|  |     { | ||||||
|  |         'driver_handles_share_servers': 'False',          #\ | ||||||
|  |         'share_backend_name': 'My Backend',               # backend level | ||||||
|  |         'vendor_name': 'MY',                              # mandatory/fixed | ||||||
|  |         'driver_version': '1.0',                          # stats & capabilities | ||||||
|  |         'storage_protocol': 'NFS_CIFS',                   #/ | ||||||
|  |                                                           #\ | ||||||
|  |         'my_capability_1': 'custom_val',                  # "my" optional vendor | ||||||
|  |         'my_capability_2': True,                          # stats & capabilities | ||||||
|  |                                                           #/ | ||||||
|  |         'share_group_stats': { | ||||||
|  |                                                           #\ | ||||||
|  |                 'my_group_capability_1': 'custom_val',    # "my" optional vendor | ||||||
|  |                 'my_group_capability_2': True,            # stats & group capabilities | ||||||
|  |                                                           #/ | ||||||
|  |                 'consistent_snapshot_support': 'host',    #\ | ||||||
|  |                                                           # common group capabilities | ||||||
|  |                                                           #/ | ||||||
|  |             }, | ||||||
|  |          ] | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |  | ||||||
| .. note:: | .. note:: | ||||||
|  |  | ||||||
|   for more information please see |   for more information please see :doc:`../admin/group_capabilities_and_extra_specs` | ||||||
|   `group capabilities <https://docs.openstack.org/manila/latest/admin/group_capabilities_and_extra_specs.html>`_ |  | ||||||
|  |  | ||||||
| Share Replication | Share Replication | ||||||
| ----------------- | ----------------- | ||||||
| @@ -219,8 +325,7 @@ recovery) or for load sharing. In order to utilize this feature, drivers must | |||||||
| report the ``replication_type`` they support as a capability and implement | report the ``replication_type`` they support as a capability and implement | ||||||
| necessary methods. | necessary methods. | ||||||
|  |  | ||||||
| More details can be found at: | More details can be found at: :doc:`../admin/shared-file-systems-share-replication` | ||||||
| https://docs.openstack.org/manila/latest/admin/shared-file-systems-share-replication.html |  | ||||||
|  |  | ||||||
| Update "used_size" of shares | Update "used_size" of shares | ||||||
| ---------------------------- | ---------------------------- | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Goutham Pacha Ravi
					Goutham Pacha Ravi