Add doc for Share Replication
- Document extra_spec and capabilities involved - Document driver interfaces properly to please Sphinx - Document scheduler behavior - Document replica and snapshot workflows - Fix trailing white spaces in the descriptions of capabilities Change-Id: I054aebda9618968ab8bd3881ccdd8164e1283682 Closes-Bug: #1544812
This commit is contained in:
parent
ffc0d5962a
commit
f14808a2d1
@ -14,7 +14,7 @@
|
|||||||
Introduction to Manila Shared Filesystem Management Service
|
Introduction to Manila Shared Filesystem Management Service
|
||||||
===========================================================
|
===========================================================
|
||||||
|
|
||||||
:term:`Manila` is the File Share service project for OpenStack. To administer the
|
:term:`manila` is the File Share service project for OpenStack. To administer the
|
||||||
OpenStack File Share service, it is helpful to understand a number of concepts
|
OpenStack File Share service, it is helpful to understand a number of concepts
|
||||||
like share networks, shares, multi-tenancy and back ends that can be configured
|
like share networks, shares, multi-tenancy and back ends that can be configured
|
||||||
with Manila. When configuring the File Share service, it is required to declare
|
with Manila. When configuring the File Share service, it is required to declare
|
||||||
|
@ -74,8 +74,8 @@ The CapabilitiesFilter uses the following for matching operators:
|
|||||||
|
|
||||||
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 satisfies
|
||||||
the comparison of strings in capability and specification. For example,
|
the comparison of strings in capability and specification. For example,
|
||||||
if "capabilities:replication_type s== dr", a host that reports replication_type of
|
if "capabilities:replication_type s== dr", a host that reports
|
||||||
"dr" will be chosen.
|
replication_type of "dr" will be chosen.
|
||||||
|
|
||||||
For vendor-specific capabilities (which need to be visible to the
|
For vendor-specific capabilities (which need to be visible to the
|
||||||
CapabilityFilter), it is recommended to use the vendor prefix followed
|
CapabilityFilter), it is recommended to use the vendor prefix followed
|
||||||
@ -133,6 +133,19 @@ be created.
|
|||||||
filter by pools that either have or don't have QoS support enabled. Added in
|
filter by pools that either have or don't have QoS support enabled. Added in
|
||||||
Mitaka.
|
Mitaka.
|
||||||
|
|
||||||
|
* `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. Added in
|
||||||
|
Mitaka.
|
||||||
|
|
||||||
Reporting Capabilities
|
Reporting Capabilities
|
||||||
----------------------
|
----------------------
|
||||||
Drivers report capabilities as part of the updated stats (e.g. capacity)
|
Drivers report capabilities as part of the updated stats (e.g. capacity)
|
||||||
@ -173,10 +186,19 @@ example vendor prefix:
|
|||||||
'thin_provisioning': True, #
|
'thin_provisioning': True, #
|
||||||
'max_over_subscription_ratio': 10, # (mandatory for thin)
|
'max_over_subscription_ratio': 10, # (mandatory for thin)
|
||||||
'provisioned_capacity_gb': 270, # (mandatory for thin)
|
'provisioned_capacity_gb': 270, # (mandatory for thin)
|
||||||
|
#
|
||||||
|
#
|
||||||
|
'replication_type': 'dr', # this backend supports
|
||||||
|
# replication_type 'dr'
|
||||||
#/
|
#/
|
||||||
'my_dying_disks': 100, #\
|
'my_dying_disks': 100, #\
|
||||||
'my_super_hero_1': 'Hulk', # "my" optional vendor
|
'my_super_hero_1': 'Hulk', # "my" optional vendor
|
||||||
'my_super_hero_2': 'Spider-Man' # stats & capabilities
|
'my_super_hero_2': 'Spider-Man', # stats & capabilities
|
||||||
|
#/
|
||||||
|
#\
|
||||||
|
# can replicate to other
|
||||||
|
'replication_domain': 'asgard', # backends in
|
||||||
|
# replication_domain 'asgard'
|
||||||
#/
|
#/
|
||||||
},
|
},
|
||||||
{'pool_name': 'thick pool',
|
{'pool_name': 'thick pool',
|
||||||
@ -187,6 +209,7 @@ example vendor prefix:
|
|||||||
'dedupe': False,
|
'dedupe': False,
|
||||||
'compression': False,
|
'compression': False,
|
||||||
'thin_provisioning': False,
|
'thin_provisioning': False,
|
||||||
|
'replication_type': None,
|
||||||
'my_dying_disks': 200,
|
'my_dying_disks': 200,
|
||||||
'my_super_hero_1': 'Batman',
|
'my_super_hero_1': 'Batman',
|
||||||
'my_super_hero_2': 'Robin',
|
'my_super_hero_2': 'Robin',
|
||||||
|
@ -94,7 +94,11 @@ function correctly in manila, such as:
|
|||||||
- compression: whether the backend supports compressed shares;
|
- compression: whether the backend supports compressed shares;
|
||||||
- thin_provisioning: whether the backend is overprovisioning shares;
|
- thin_provisioning: whether the backend is overprovisioning shares;
|
||||||
- pools: list of storage pools managed by this driver instance;
|
- pools: list of storage pools managed by this driver instance;
|
||||||
- qos: whether the backend supports quality of service for shares.
|
- qos: whether the backend supports quality of service for shares;
|
||||||
|
- replication_domain: string specifying a common group name for all backends
|
||||||
|
that can replicate between each other;
|
||||||
|
- replication_type: string specifying the type of replication supported by
|
||||||
|
the driver. Can be one of ('readable', 'writable' or 'dr').
|
||||||
|
|
||||||
.. note:: for more information please see http://docs.openstack.org/developer/manila/devref/capabilities_and_extra_specs.html
|
.. note:: for more information please see http://docs.openstack.org/developer/manila/devref/capabilities_and_extra_specs.html
|
||||||
|
|
||||||
@ -199,3 +203,14 @@ consistency of multiple shares. In order to make use of this feature, driver
|
|||||||
vendors must report this capability and implement its functions to work
|
vendors must report this capability and implement its functions to work
|
||||||
according to the backend, so the feature can be properly invoked through
|
according to the backend, so the feature can be properly invoked through
|
||||||
manila API.
|
manila API.
|
||||||
|
|
||||||
|
Share Replication
|
||||||
|
-----------------
|
||||||
|
|
||||||
|
Replicas of shares can be created for either data protection (for disaster
|
||||||
|
recovery) or for load sharing. In order to utilize this feature, drivers must
|
||||||
|
report the ``replication_type`` they support as a capability and implement
|
||||||
|
necessary methods.
|
||||||
|
|
||||||
|
More details can be found at:
|
||||||
|
http://docs.openstack.org/developer/manila/devref/share_replication.html
|
||||||
|
@ -78,6 +78,7 @@ Module Reference
|
|||||||
fakes
|
fakes
|
||||||
manila
|
manila
|
||||||
ganesha
|
ganesha
|
||||||
|
share_replication
|
||||||
|
|
||||||
Capabilities and Extra-Specs
|
Capabilities and Extra-Specs
|
||||||
----------------------------
|
----------------------------
|
||||||
|
@ -50,6 +50,17 @@ The following operations are supported on Clustered Data ONTAP:
|
|||||||
- Create consistency group from CG snapshot
|
- Create consistency group from CG snapshot
|
||||||
- Create CG snapshot
|
- Create CG snapshot
|
||||||
- Delete CG snapshot
|
- Delete CG snapshot
|
||||||
|
- Create a replica (DHSS=False)
|
||||||
|
- Promote a replica (DHSS=False)
|
||||||
|
- Delete a replica (DHSS=False)
|
||||||
|
- Update a replica (DHSS=False)
|
||||||
|
- Create a replicated snapshot (DHSS=False)
|
||||||
|
- Delete a replicated snapshot (DHSS=False)
|
||||||
|
- Update a replicated snapshot (DHSS=False)
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
|
||||||
|
:term:`DHSS` is abbreviated from `driver_handles_share_servers`.
|
||||||
|
|
||||||
Supported Operating Modes
|
Supported Operating Modes
|
||||||
-------------------------
|
-------------------------
|
||||||
|
@ -90,6 +90,13 @@ Driver methods that are wrapped with hooks
|
|||||||
- publish_service_capabilities
|
- publish_service_capabilities
|
||||||
- shrink_share
|
- shrink_share
|
||||||
- unmanage_share
|
- unmanage_share
|
||||||
|
- create_share_replica
|
||||||
|
- promote_share_replica
|
||||||
|
- delete_share_replica
|
||||||
|
- update_share_replica
|
||||||
|
- create_replicated_snapshot
|
||||||
|
- delete_replicated_snapshot
|
||||||
|
- update_replicated_snapshot
|
||||||
|
|
||||||
Above list with wrapped methods can be extended in future.
|
Above list with wrapped methods can be extended in future.
|
||||||
|
|
||||||
|
313
doc/source/devref/share_replication.rst
Normal file
313
doc/source/devref/share_replication.rst
Normal file
@ -0,0 +1,313 @@
|
|||||||
|
..
|
||||||
|
Copyright (c) 2016 Goutham Pacha Ravi
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License"); you may
|
||||||
|
not use this file except in compliance with the License. You may obtain
|
||||||
|
a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
||||||
|
WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||||
|
License for the specific language governing permissions and limitations
|
||||||
|
under the License.
|
||||||
|
|
||||||
|
|
||||||
|
=================
|
||||||
|
Share Replication
|
||||||
|
=================
|
||||||
|
|
||||||
|
As of the Mitaka release of OpenStack, :term:`manila` supports replication of
|
||||||
|
shares between different pools for drivers that operate with
|
||||||
|
``driver_handles_share_servers=False`` mode. These pools may be on different
|
||||||
|
backends or within the same backend. This feature can be used as a disaster
|
||||||
|
recovery solution or as a load sharing mirroring solution depending upon the
|
||||||
|
replication style chosen, the capability of the driver and the configuration
|
||||||
|
of backends.
|
||||||
|
|
||||||
|
This feature assumes and relies on the fact that share drivers will be
|
||||||
|
responsible for communicating with ALL storage controllers necessary to
|
||||||
|
achieve any replication tasks, even if that involves sending commands to
|
||||||
|
other storage controllers in other Availability Zones (or AZs).
|
||||||
|
|
||||||
|
End users would be able to create and manage their replicas, alongside their
|
||||||
|
shares and snapshots.
|
||||||
|
|
||||||
|
|
||||||
|
Storage availability zones and replication domains
|
||||||
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
Replication is supported within the same availability zone, but in an ideal
|
||||||
|
solution, an Availability Zone should be perceived as a single failure domain.
|
||||||
|
So this feature provides the most value in an inter-AZ replication use case.
|
||||||
|
|
||||||
|
The ``replication_domain`` option is a backend specific StrOpt option to be
|
||||||
|
used within ``manila.conf``. The value can be any ASCII string. Two backends
|
||||||
|
that can replicate between each other would have the same
|
||||||
|
``replication_domain``. This comes from the premise that manila expects
|
||||||
|
Share Replication to be performed between backends that have similar
|
||||||
|
characteristics.
|
||||||
|
|
||||||
|
When scheduling new replicas, the scheduler takes into account the
|
||||||
|
``replication_domain`` option to match similar backends. It also ensures that
|
||||||
|
only one replica can be scheduled per pool. When backends report multiple
|
||||||
|
pools, manila would allow for replication between two pools on the same
|
||||||
|
backend.
|
||||||
|
|
||||||
|
The ``replication_domain`` option is meant to be used in conjunction with the
|
||||||
|
``storage_availability_zone`` option to utilize this solution for Data
|
||||||
|
Protection/Disaster Recovery.
|
||||||
|
|
||||||
|
|
||||||
|
Replication types
|
||||||
|
~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
When creating a share that is meant to have replicas in the future, the user
|
||||||
|
will use a ``share_type`` with an extra_spec, :term:`replication_type` set to
|
||||||
|
a valid replication type that manila supports. Drivers must report the
|
||||||
|
replication type that they support as the :term:`replication_type`
|
||||||
|
capability during the ``_update_share_stats()`` call.
|
||||||
|
|
||||||
|
Three types of replication are currently supported:
|
||||||
|
|
||||||
|
**writable**
|
||||||
|
Synchronously replicated shares where all replicas are writable.
|
||||||
|
Promotion is not supported and not needed.
|
||||||
|
|
||||||
|
**readable**
|
||||||
|
Mirror-style replication with a primary (writable) copy
|
||||||
|
and one or more secondary (read-only) copies which can become writable
|
||||||
|
after a promotion.
|
||||||
|
|
||||||
|
**dr (for Disaster Recovery)**
|
||||||
|
Generalized replication with secondary copies that are inaccessible until
|
||||||
|
they are promoted to become the ``active`` replica.
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
|
||||||
|
The term :term:`active` replica refers to the ``primary`` share. In
|
||||||
|
:term:`writable` style of replication, all replicas are :term:`active`,
|
||||||
|
and there could be no distinction of a ``primary`` share. In
|
||||||
|
:term:`readable` and :term:`dr` styles of replication, a ``secondary``
|
||||||
|
replica may be referred to as ``passive``, ``non-active`` or simply
|
||||||
|
``replica``.
|
||||||
|
|
||||||
|
|
||||||
|
Health of a share replica
|
||||||
|
~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
Apart from the ``status`` attribute, share replicas have the
|
||||||
|
:term:`replica_state` attribute to denote the state of the replica. The
|
||||||
|
``primary`` replica will have it's :term:`replica_state` attribute set to
|
||||||
|
:term:`active`. A ``secondary`` replica may have one of the following values as
|
||||||
|
its :term:`replica_state`:
|
||||||
|
|
||||||
|
**in_sync**
|
||||||
|
The replica is up to date with the active replica
|
||||||
|
(possibly within a backend specific :term:`recovery point objective`).
|
||||||
|
|
||||||
|
**out_of_sync**
|
||||||
|
The replica has gone out of date (all new replicas start out in this
|
||||||
|
:term:`replica_state`).
|
||||||
|
|
||||||
|
**error**
|
||||||
|
When the scheduler failed to schedule this replica or some potentially
|
||||||
|
irrecoverable damage occurred with regard to updating data for this
|
||||||
|
replica.
|
||||||
|
|
||||||
|
Manila requests periodic update of the :term:`replica_state` of all non-active
|
||||||
|
replicas. The update occurs with respect to an interval defined through the
|
||||||
|
``replica_state_update_interval`` option in ``manila.conf``.
|
||||||
|
|
||||||
|
Administrators have an option of initiating a ``resync`` of a secondary
|
||||||
|
replica (for :term:`readable` and :term:`dr` types of replication). This could
|
||||||
|
be performed before a planned failover operation in order to have the most
|
||||||
|
up-to-date data on the replica.
|
||||||
|
|
||||||
|
|
||||||
|
Promotion
|
||||||
|
~~~~~~~~~
|
||||||
|
|
||||||
|
For :term:`readable` and :term:`dr` styles, we refer to the task of
|
||||||
|
switching a ``non-active`` replica with the :term:`active` replica as
|
||||||
|
`promotion`. For the :term:`writable` style of replication, promotion does
|
||||||
|
not make sense since all replicas are :term:`active` (or writable) at all
|
||||||
|
given points of time.
|
||||||
|
|
||||||
|
The ``status`` attribute of the non-active replica being promoted will be set
|
||||||
|
to :term:`replication_change` during its promotion. This has been classified
|
||||||
|
as a ``busy`` state and hence API interactions with the share are restricted
|
||||||
|
while one of its replicas is in this state.
|
||||||
|
|
||||||
|
Promotion of replicas with :term:`replica_state` set to ``error`` may not be
|
||||||
|
fully supported by the backend. However, manila allows the action as an
|
||||||
|
administrator feature and such an attempt may be honored by backends if
|
||||||
|
possible.
|
||||||
|
|
||||||
|
When multiple replicas exist, multiple replication relationships
|
||||||
|
between shares may need to be redefined at the backend during the promotion
|
||||||
|
operation. If the driver fails at this stage, the replicas may be left in an
|
||||||
|
inconsistent state. The share manager will set all replicas to have the
|
||||||
|
``status`` attribute set to ``error``. Recovery from this state would require
|
||||||
|
administrator intervention.
|
||||||
|
|
||||||
|
|
||||||
|
Snapshots
|
||||||
|
~~~~~~~~~
|
||||||
|
|
||||||
|
If the driver supports snapshots, the replication of a snapshot is expected
|
||||||
|
to be initiated simultaneously with the creation of the snapshot on the
|
||||||
|
:term:`active` replica. Manila tracks snapshots across replicas as separate
|
||||||
|
snapshot instances. The aggregate snapshot object itself will be in
|
||||||
|
``creating`` state until it is ``available`` across all of the share's replicas
|
||||||
|
that have their :term:`replica_state` attribute set to :term:`active` or
|
||||||
|
``in_sync``.
|
||||||
|
|
||||||
|
Therefore, for a driver that supports snapshots, the definition of being
|
||||||
|
``in_sync`` with the primary is not only that data is ensured (within the
|
||||||
|
:term:`recovery point objective`), but also that any 'available' snapshots
|
||||||
|
on the primary are ensured on the replica as well. If the snapshots cannot
|
||||||
|
be ensured, the :term:`replica_state` *must* be reported to manila as being
|
||||||
|
``out_of_sync`` until the snapshots have been replicated.
|
||||||
|
|
||||||
|
When a snapshot instance has its ``status`` attribute set to ``creating`` or
|
||||||
|
``deleting``, manila will poll the respective drivers for a status update. As
|
||||||
|
described earlier, the parent snapshot itself will be ``available`` only when
|
||||||
|
its instances across the :term:`active` and ``in_sync`` replicas of the share
|
||||||
|
are ``available``. The polling interval will be the same as
|
||||||
|
``replica_state_update_interval``.
|
||||||
|
|
||||||
|
|
||||||
|
Access Rules
|
||||||
|
~~~~~~~~~~~~
|
||||||
|
|
||||||
|
Access rules are not meant to be different across the replicas of the share.
|
||||||
|
Manila expects drivers to handle these access rules effectively depending on
|
||||||
|
the style of replication supported. For example, the :term:`dr` style of
|
||||||
|
replication does mean that the non-active replicas are inaccessible, so if
|
||||||
|
read-write rules are expected, then the rules should be applied on the
|
||||||
|
:term:`active` replica only. Similarly, drivers that
|
||||||
|
support :term:`readable` replication type should apply any read-write
|
||||||
|
rules as read-only for the non-active replicas.
|
||||||
|
|
||||||
|
Drivers will receive all the access rules in ``create_replica``,
|
||||||
|
``delete_replica`` and ``update_replica_state`` calls and have ample
|
||||||
|
opportunity to reconcile these rules effectively across replicas.
|
||||||
|
|
||||||
|
|
||||||
|
Understanding Replication Workflows
|
||||||
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
Creating a share that supports replication
|
||||||
|
------------------------------------------
|
||||||
|
Administrators can create a share type with extra-spec
|
||||||
|
:term:`replication_type`, matching the style of replication the desired backend
|
||||||
|
supports. Users can use the share type to create a new share that
|
||||||
|
allows/supports replication. A replicated share always starts out with one
|
||||||
|
replica, the ``primary`` share itself.
|
||||||
|
|
||||||
|
The :term:`manila-scheduler` service will filter and weigh available pools to
|
||||||
|
find a suitable pool for the share being created. In particular,
|
||||||
|
|
||||||
|
* The ``CapabilityFilter`` will match the :term:`replication_type` extra_spec
|
||||||
|
in the request share_type with the ``replication_type`` capability reported
|
||||||
|
by a pool.
|
||||||
|
* The ``ShareReplicationFilter`` will further ensure that the pool has a
|
||||||
|
non-empty ``replication_domain`` capability being reported as well.
|
||||||
|
* The ``AvailabilityZoneFilter`` will ensure that the availability_zone
|
||||||
|
requested matches with the pool's availability zone.
|
||||||
|
|
||||||
|
Creating a replica
|
||||||
|
------------------
|
||||||
|
The user has to specify the share name/id of the share that is supposed to be
|
||||||
|
replicated and optionally an availability zone for the replica to exist in.
|
||||||
|
The replica inherits the parent share's share_type and associated
|
||||||
|
extra_specs. Scheduling of the replica is similar to that of the share.
|
||||||
|
|
||||||
|
* The `ShareReplicationFilter` will ensure that the pool is within
|
||||||
|
the same ``replication_domain`` as the :term:`active` replica and also
|
||||||
|
ensures that the pool does not already have a replica for that share.
|
||||||
|
|
||||||
|
Drivers supporting :term:`writable` style **must** set the
|
||||||
|
:term:`replica_state` attribute to :term:`active` when the replica has been
|
||||||
|
created and is ``available``.
|
||||||
|
|
||||||
|
Deleting a replica
|
||||||
|
------------------
|
||||||
|
Users can remove replicas that have their `status` attribute set to
|
||||||
|
``error``, ``in_sync`` or ``out_of_sync``. They could even delete an
|
||||||
|
:term:`active` replica as long as there is another :term:`active` replica
|
||||||
|
(as could be the case with `writable` replication style). Before the
|
||||||
|
``delete_replica`` call is made to the driver, an update_access call is made
|
||||||
|
to ensure access rules are safely removed for the replica.
|
||||||
|
|
||||||
|
Administrators may also ``force-delete`` replicas. Any driver exceptions will
|
||||||
|
only be logged and not re-raised; the replica will be purged from manila's
|
||||||
|
database.
|
||||||
|
|
||||||
|
Promoting a replica
|
||||||
|
-------------------
|
||||||
|
Users can promote replicas that have their :term:`replica_state` attribute set
|
||||||
|
to ``in_sync``. Administrators can attempt to promote replicas that have their
|
||||||
|
:term:`replica_state` attribute set to ``out_of_sync`` or ``error``. During a
|
||||||
|
promotion, if the driver raises an exception, all replicas will have their
|
||||||
|
`status` attribute set to `error` and recovery from this state will require
|
||||||
|
administrator intervention.
|
||||||
|
|
||||||
|
Resyncing a replica
|
||||||
|
-------------------
|
||||||
|
Prior to a planned failover, an administrator could attempt to update the
|
||||||
|
data on the replica. The ``update_replica_state`` call will be made during
|
||||||
|
such an action, giving drivers an opportunity to push the latest updates from
|
||||||
|
the `active` replica to the secondaries.
|
||||||
|
|
||||||
|
Creating a snapshot
|
||||||
|
-------------------
|
||||||
|
When a user takes a snapshot of a share that has replicas, manila creates as
|
||||||
|
many snapshot instances as there are share replicas. These snapshot
|
||||||
|
instances all begin with their `status` attribute set to `creating`. The driver
|
||||||
|
is expected to create the snapshot of the ``active`` replica and then begin to
|
||||||
|
replicate this snapshot as soon as the :term:`active` replica's
|
||||||
|
snapshot instance is created and becomes ``available``.
|
||||||
|
|
||||||
|
Deleting a snapshot
|
||||||
|
-------------------
|
||||||
|
When a user deletes a snapshot, the snapshot instances corresponding to each
|
||||||
|
replica of the share have their ``status`` attribute set to ``deleting``.
|
||||||
|
Drivers must update their secondaries as soon as the :term:`active` replica's
|
||||||
|
snapshot instance is deleted.
|
||||||
|
|
||||||
|
|
||||||
|
Driver Interfaces
|
||||||
|
~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
As part of the ``_update_share_stats()`` call, the base driver reports the
|
||||||
|
``replication_domain`` capability. Drivers are expected to update the
|
||||||
|
:term:`replication_type` capability.
|
||||||
|
|
||||||
|
Drivers must implement the methods enumerated below in order to support
|
||||||
|
replication. ``promote_replica``, ``update_replica_state`` and
|
||||||
|
``update_replicated_snapshot`` need not be implemented by drivers that support
|
||||||
|
the :term:`writable` style of replication. The snapshot methods
|
||||||
|
``create_replicated_snapshot``, ``delete_replicated_snapshot`` and
|
||||||
|
``update_replicated_snapshot`` need not be implemented by a driver that does
|
||||||
|
not support snapshots.
|
||||||
|
|
||||||
|
Each driver request is made on a specific host. Create/delete operations
|
||||||
|
on secondary replicas are always made on the destination host. Create/delete
|
||||||
|
operations on snapshots are always made on the :term:`active` replica's host.
|
||||||
|
``update_replica_state`` and ``update_replicated_snapshot`` calls are made on
|
||||||
|
the host that the replica or snapshot resides on.
|
||||||
|
|
||||||
|
Share Replica interfaces:
|
||||||
|
-------------------------
|
||||||
|
|
||||||
|
.. autoclass:: manila.share.driver.ShareDriver
|
||||||
|
:members: create_replica, delete_replica, promote_replica, update_replica_state
|
||||||
|
|
||||||
|
Replicated Snapshot interfaces:
|
||||||
|
-------------------------------
|
||||||
|
|
||||||
|
.. autoclass:: manila.share.driver.ShareDriver
|
||||||
|
:members: create_replicated_snapshot, delete_replicated_snapshot, update_replicated_snapshot
|
@ -4,7 +4,7 @@ Glossary
|
|||||||
|
|
||||||
.. glossary::
|
.. glossary::
|
||||||
|
|
||||||
Manila
|
manila
|
||||||
OpenStack project to provide "Shared Filesystems as a service".
|
OpenStack project to provide "Shared Filesystems as a service".
|
||||||
|
|
||||||
manila-api
|
manila-api
|
||||||
@ -13,8 +13,8 @@ Glossary
|
|||||||
There is :term:`python-manilaclient` to interact with the API.
|
There is :term:`python-manilaclient` to interact with the API.
|
||||||
|
|
||||||
python-manilaclient
|
python-manilaclient
|
||||||
Command line interface to interact with :term:`Manila` via :term:`manila-api` and also a
|
Command line interface to interact with :term:`manila` via :term:`manila-api` and also a
|
||||||
Python module to interact programmatically with :term:`Manila`.
|
Python module to interact programmatically with :term:`manila`.
|
||||||
|
|
||||||
manila-scheduler
|
manila-scheduler
|
||||||
Responsible for scheduling/routing requests to the appropriate :term:`manila-share` service.
|
Responsible for scheduling/routing requests to the appropriate :term:`manila-share` service.
|
||||||
@ -27,3 +27,53 @@ Glossary
|
|||||||
Acronym for 'driver handles share servers'. It defines two different share driver modes
|
Acronym for 'driver handles share servers'. It defines two different share driver modes
|
||||||
when they either do handle share servers or not. Each driver is allowed to work only in
|
when they either do handle share servers or not. Each driver is allowed to work only in
|
||||||
one mode at once. Requirement is to support, at least, one mode.
|
one mode at once. Requirement is to support, at least, one mode.
|
||||||
|
|
||||||
|
replication_type
|
||||||
|
Type of replication supported by a share driver. If the share driver supports replication
|
||||||
|
it will report a valid value to the :term:`manila-scheduler`. The value of this
|
||||||
|
capability can be one of :term:`readable`, :term:`writable` or :term:`dr`.
|
||||||
|
|
||||||
|
readable
|
||||||
|
A type of replication supported by :term:`manila` in which there is one :term:`active`
|
||||||
|
replica (also referred to as `primary` share) and one or more non-active replicas (also
|
||||||
|
referred to as `secondary` shares). All share replicas have at least one export location
|
||||||
|
and are mountable. However, the non-active replicas cannot be written to until after
|
||||||
|
promotion.
|
||||||
|
|
||||||
|
writable
|
||||||
|
A type of replication supported by :term:`manila` in which all share replicas are
|
||||||
|
writable. There is no requirement of a promotion since replication is synchronous.
|
||||||
|
All share replicas have one or more export locations each and are mountable.
|
||||||
|
|
||||||
|
dr
|
||||||
|
Acronym for `Disaster Recovery`. It is a type of replication supported by :term:`manila`
|
||||||
|
in which there is one :term:`active` replica (also referred to as `primary` share) and
|
||||||
|
one or more non-active replicas (also referred to as `secondary` shares). Only the
|
||||||
|
`active` replica has one or more export locations and can be mounted. The non-active
|
||||||
|
replicas are inaccessible until after promotion.
|
||||||
|
|
||||||
|
active
|
||||||
|
In :term:`manila`, an `active` replica refers to a share that can be written to. In
|
||||||
|
`readable` and `dr` styles of replication, there is only one `active` replica at any given
|
||||||
|
point in time. Thus, it may also be referred to as the `primary` share. In `writable`
|
||||||
|
style of replication, all replicas are writable and there may be no distinction of a
|
||||||
|
`primary` share.
|
||||||
|
|
||||||
|
replica_state
|
||||||
|
An attribute of the Share Instance (Share Replica) model in :term:`manila`. If the value is
|
||||||
|
:term:`active`, it refers to the type of the replica. If the value is one of `in_sync` or
|
||||||
|
`out_of_sync`, it refers to the state of consistency of data between the :term:`active`
|
||||||
|
replica and the share replica. If the value is `error`, a potentially irrecoverable
|
||||||
|
error may have occurred during the update of data between the :term:`active` replica and
|
||||||
|
the share replica.
|
||||||
|
|
||||||
|
replication_change
|
||||||
|
State of a non-active replica when it is being promoted to become the :term:`active`
|
||||||
|
replica.
|
||||||
|
|
||||||
|
recovery point objective
|
||||||
|
Abbreviated as ``RPO``, recovery point objective is a target window of time between which
|
||||||
|
a storage backend may guarantee that data is consistent between a primary and a secondary
|
||||||
|
replica. This window is **not** managed by :term:`manila`.
|
||||||
|
|
||||||
|
|
||||||
|
@ -512,8 +512,8 @@ class ShareDriver(object):
|
|||||||
may be added by the driver instead of R/W. Note that raising an
|
may be added by the driver instead of R/W. Note that raising an
|
||||||
exception *will* result in the access_rules_status on the replica,
|
exception *will* result in the access_rules_status on the replica,
|
||||||
and the share itself being "out_of_sync". Drivers can sync on the
|
and the share itself being "out_of_sync". Drivers can sync on the
|
||||||
valid access rules that are provided on the create_replica and
|
valid access rules that are provided on the ``create_replica`` and
|
||||||
promote_replica calls.
|
``promote_replica`` calls.
|
||||||
|
|
||||||
:param context: Current context
|
:param context: Current context
|
||||||
:param share: Share model with share data.
|
:param share: Share model with share data.
|
||||||
@ -1049,15 +1049,16 @@ class ShareDriver(object):
|
|||||||
access_rules, replica_snapshots, share_server=None):
|
access_rules, replica_snapshots, share_server=None):
|
||||||
"""Replicate the active replica to a new replica on this backend.
|
"""Replicate the active replica to a new replica on this backend.
|
||||||
|
|
||||||
NOTE: This call is made on the host that the new replica is
|
.. note::
|
||||||
being created upon.
|
This call is made on the host that the new replica is being created
|
||||||
|
upon.
|
||||||
|
|
||||||
:param context: Current context
|
:param context: Current context
|
||||||
:param replica_list: List of all replicas for a particular share.
|
:param replica_list: List of all replicas for a particular share.
|
||||||
This list also contains the replica to be created. The 'active'
|
This list also contains the replica to be created. The 'active'
|
||||||
replica will have its 'replica_state' attr set to 'active'.
|
replica will have its 'replica_state' attr set to 'active'.
|
||||||
EXAMPLE:
|
|
||||||
.. code::
|
Example::
|
||||||
|
|
||||||
[
|
[
|
||||||
{
|
{
|
||||||
@ -1086,9 +1087,10 @@ class ShareDriver(object):
|
|||||||
},
|
},
|
||||||
...
|
...
|
||||||
]
|
]
|
||||||
|
|
||||||
:param new_replica: The share replica dictionary.
|
:param new_replica: The share replica dictionary.
|
||||||
EXAMPLE:
|
|
||||||
.. code::
|
Example::
|
||||||
|
|
||||||
{
|
{
|
||||||
'id': 'e82ff8b6-65f0-11e5-9d70-feff819cdc9f',
|
'id': 'e82ff8b6-65f0-11e5-9d70-feff819cdc9f',
|
||||||
@ -1109,36 +1111,45 @@ class ShareDriver(object):
|
|||||||
'share_server_id': 'e6155221-ea00-49ef-abf9-9f89b7dd900a',
|
'share_server_id': 'e6155221-ea00-49ef-abf9-9f89b7dd900a',
|
||||||
'share_server': <models.ShareServer> or None,
|
'share_server': <models.ShareServer> or None,
|
||||||
}
|
}
|
||||||
:param access_rules: A list of access rules that other instances of
|
|
||||||
the share already obey. Drivers are expected to apply access rules
|
:param access_rules: A list of access rules.
|
||||||
to the new replica or disregard access rules that don't apply.
|
These are rules that other instances of the share already obey.
|
||||||
EXAMPLE:
|
Drivers are expected to apply access rules to the new replica or
|
||||||
.. code::
|
disregard access rules that don't apply.
|
||||||
[ {
|
|
||||||
|
Example::
|
||||||
|
|
||||||
|
[
|
||||||
|
{
|
||||||
'id': 'f0875f6f-766b-4865-8b41-cccb4cdf1676',
|
'id': 'f0875f6f-766b-4865-8b41-cccb4cdf1676',
|
||||||
'deleted' = False,
|
'deleted' = False,
|
||||||
'share_id' = 'f0e4bb5e-65f0-11e5-9d70-feff819cdc9f',
|
'share_id' = 'f0e4bb5e-65f0-11e5-9d70-feff819cdc9f',
|
||||||
'access_type' = 'ip',
|
'access_type' = 'ip',
|
||||||
'access_to' = '172.16.20.1',
|
'access_to' = '172.16.20.1',
|
||||||
'access_level' = 'rw',
|
'access_level' = 'rw',
|
||||||
}]
|
}
|
||||||
:param replica_snapshots: List of dictionaries of snapshot instances
|
]
|
||||||
for each snapshot of the share whose 'aggregate_status' property was
|
|
||||||
reported to be 'available' when the share manager initiated this
|
:param replica_snapshots: List of dictionaries of snapshot instances.
|
||||||
request. Each list member will have two sub dictionaries:
|
This includes snapshot instances of every snapshot of the share
|
||||||
'active_replica_snapshot' and 'share_replica_snapshot'. The 'active'
|
whose 'aggregate_status' property was reported to be 'available'
|
||||||
replica snapshot corresponds to the instance of the snapshot on any
|
when the share manager initiated this request. Each list member
|
||||||
of the 'active' replicas of the share while share_replica_snapshot
|
will have two sub dictionaries: 'active_replica_snapshot' and
|
||||||
corresponds to the snapshot instance for the specific replica that
|
'share_replica_snapshot'. The 'active' replica snapshot corresponds
|
||||||
will need to exist on the new share replica that is being created.
|
to the instance of the snapshot on any of the 'active' replicas of
|
||||||
The driver needs to ensure that this snapshot instance is truly
|
the share while share_replica_snapshot corresponds to the snapshot
|
||||||
available before transitioning the replica from 'out_of_sync' to
|
instance for the specific replica that will need to exist on the
|
||||||
'in_sync'. Snapshots instances for snapshots that have an
|
new share replica that is being created. The driver needs to ensure
|
||||||
'aggregate_status' of 'creating' or 'deleting' will be polled for in
|
that this snapshot instance is truly available before transitioning
|
||||||
the update_replicated_snapshot method.
|
the replica from 'out_of_sync' to 'in_sync'. Snapshots instances
|
||||||
EXAMPLE:
|
for snapshots that have an 'aggregate_status' of 'creating' or
|
||||||
.. code::
|
'deleting' will be polled for in the ``update_replicated_snapshot``
|
||||||
[ {
|
method.
|
||||||
|
|
||||||
|
Example::
|
||||||
|
|
||||||
|
[
|
||||||
|
{
|
||||||
'active_replica_snapshot': {
|
'active_replica_snapshot': {
|
||||||
'id': '8bda791c-7bb6-4e7b-9b64-fefff85ff13e',
|
'id': '8bda791c-7bb6-4e7b-9b64-fefff85ff13e',
|
||||||
'share_instance_id': '10e49c3e-aca9-483b-8c2d-1c337b38d6af',
|
'share_instance_id': '10e49c3e-aca9-483b-8c2d-1c337b38d6af',
|
||||||
@ -1153,17 +1164,27 @@ class ShareDriver(object):
|
|||||||
'provider_location': None,
|
'provider_location': None,
|
||||||
...
|
...
|
||||||
},
|
},
|
||||||
}]
|
}
|
||||||
:param share_server: <models.ShareServer> or None,
|
]
|
||||||
|
|
||||||
|
:param share_server: <models.ShareServer> or None
|
||||||
Share server of the replica being created.
|
Share server of the replica being created.
|
||||||
:return: None or a dictionary containing export_locations,
|
:return: None or a dictionary.
|
||||||
replica_state and access_rules_status. export_locations is a list of
|
The dictionary can contain export_locations replica_state and
|
||||||
paths and replica_state is one of active, in_sync, out_of_sync or
|
access_rules_status. export_locations is a list of paths and
|
||||||
error. A backend supporting 'writable' type replication should return
|
replica_state is one of 'active', 'in_sync', 'out_of_sync' or
|
||||||
'active' as the replica_state. Export locations should be in the
|
'error'.
|
||||||
same format as returned during the create_share call.
|
|
||||||
EXAMPLE:
|
.. important::
|
||||||
.. code::
|
|
||||||
|
A backend supporting 'writable' type replication should return
|
||||||
|
'active' as the replica_state.
|
||||||
|
|
||||||
|
Export locations should be in the same format as returned during the
|
||||||
|
``create_share`` call.
|
||||||
|
|
||||||
|
Example::
|
||||||
|
|
||||||
{
|
{
|
||||||
'export_locations': [
|
'export_locations': [
|
||||||
{
|
{
|
||||||
@ -1175,6 +1196,7 @@ class ShareDriver(object):
|
|||||||
'replica_state': 'in_sync',
|
'replica_state': 'in_sync',
|
||||||
'access_rules_status': 'in_sync',
|
'access_rules_status': 'in_sync',
|
||||||
}
|
}
|
||||||
|
|
||||||
"""
|
"""
|
||||||
raise NotImplementedError()
|
raise NotImplementedError()
|
||||||
|
|
||||||
@ -1182,15 +1204,16 @@ class ShareDriver(object):
|
|||||||
replica, share_server=None):
|
replica, share_server=None):
|
||||||
"""Delete a replica.
|
"""Delete a replica.
|
||||||
|
|
||||||
NOTE: This call is made on the host that hosts the replica being
|
.. note::
|
||||||
|
This call is made on the host that hosts the replica being
|
||||||
deleted.
|
deleted.
|
||||||
|
|
||||||
:param context: Current context
|
:param context: Current context
|
||||||
:param replica_list: List of all replicas for a particular share.
|
:param replica_list: List of all replicas for a particular share
|
||||||
This list also contains the replica to be deleted. The 'active'
|
This list also contains the replica to be deleted. The 'active'
|
||||||
replica will have its 'replica_state' attr set to 'active'.
|
replica will have its 'replica_state' attr set to 'active'.
|
||||||
EXAMPLE:
|
|
||||||
.. code::
|
Example::
|
||||||
|
|
||||||
[
|
[
|
||||||
{
|
{
|
||||||
@ -1219,9 +1242,10 @@ class ShareDriver(object):
|
|||||||
},
|
},
|
||||||
...
|
...
|
||||||
]
|
]
|
||||||
|
|
||||||
:param replica: Dictionary of the share replica being deleted.
|
:param replica: Dictionary of the share replica being deleted.
|
||||||
EXAMPLE:
|
|
||||||
.. code::
|
Example::
|
||||||
|
|
||||||
{
|
{
|
||||||
'id': 'e82ff8b6-65f0-11e5-9d70-feff819cdc9f',
|
'id': 'e82ff8b6-65f0-11e5-9d70-feff819cdc9f',
|
||||||
@ -1242,15 +1266,17 @@ class ShareDriver(object):
|
|||||||
'share_server_id': '53099868-65f1-11e5-9d70-feff819cdc9f',
|
'share_server_id': '53099868-65f1-11e5-9d70-feff819cdc9f',
|
||||||
'share_server': <models.ShareServer> or None,
|
'share_server': <models.ShareServer> or None,
|
||||||
}
|
}
|
||||||
:param replica_snapshots: A list of dictionaries containing snapshot
|
|
||||||
instances that are associated with the share replica being deleted.
|
:param replica_snapshots: List of dictionaries of snapshot instances.
|
||||||
No model updates are possible in this method. The driver should
|
The dict contains snapshot instances that are associated with the
|
||||||
return when the cleanup is completed on the backend for both,
|
share replica being deleted.
|
||||||
the snapshots and the replica itself. Drivers must handle situations
|
No model updates to snapshot instances are possible in this method.
|
||||||
where the snapshot may not yet have finished 'creating' on this
|
The driver should return when the cleanup is completed on the
|
||||||
replica.
|
backend for both, the snapshots and the replica itself. Drivers
|
||||||
EXAMPLE:
|
must handle situations where the snapshot may not yet have
|
||||||
.. code::
|
finished 'creating' on this replica.
|
||||||
|
|
||||||
|
Example::
|
||||||
|
|
||||||
[
|
[
|
||||||
{
|
{
|
||||||
@ -1269,11 +1295,13 @@ class ShareDriver(object):
|
|||||||
},
|
},
|
||||||
...
|
...
|
||||||
]
|
]
|
||||||
:param share_server: <models.ShareServer> or None,
|
|
||||||
|
:param share_server: <models.ShareServer> or None
|
||||||
Share server of the replica to be deleted.
|
Share server of the replica to be deleted.
|
||||||
:return: None.
|
:return: None.
|
||||||
:raises Exception. Any exception raised will set the share replica's
|
:raises: Exception.
|
||||||
'status' and 'replica_state' to 'error_deleting'. It will not affect
|
Any exception raised will set the share replica's 'status' and
|
||||||
|
'replica_state' attributes to 'error_deleting'. It will not affect
|
||||||
snapshots belonging to this replica.
|
snapshots belonging to this replica.
|
||||||
"""
|
"""
|
||||||
raise NotImplementedError()
|
raise NotImplementedError()
|
||||||
@ -1282,15 +1310,16 @@ class ShareDriver(object):
|
|||||||
share_server=None):
|
share_server=None):
|
||||||
"""Promote a replica to 'active' replica state.
|
"""Promote a replica to 'active' replica state.
|
||||||
|
|
||||||
NOTE: This call is made on the host that hosts the replica being
|
.. note::
|
||||||
|
This call is made on the host that hosts the replica being
|
||||||
promoted.
|
promoted.
|
||||||
|
|
||||||
:param context: Current context
|
:param context: Current context
|
||||||
:param replica_list: List of all replicas for a particular share.
|
:param replica_list: List of all replicas for a particular share
|
||||||
This list also contains the replica to be promoted. The 'active'
|
This list also contains the replica to be promoted. The 'active'
|
||||||
replica will have its 'replica_state' attr set to 'active'.
|
replica will have its 'replica_state' attr set to 'active'.
|
||||||
EXAMPLE:
|
|
||||||
.. code::
|
Example::
|
||||||
|
|
||||||
[
|
[
|
||||||
{
|
{
|
||||||
@ -1321,8 +1350,8 @@ class ShareDriver(object):
|
|||||||
]
|
]
|
||||||
|
|
||||||
:param replica: Dictionary of the replica to be promoted.
|
:param replica: Dictionary of the replica to be promoted.
|
||||||
EXAMPLE:
|
|
||||||
.. code::
|
Example::
|
||||||
|
|
||||||
{
|
{
|
||||||
'id': 'e82ff8b6-65f0-11e5-9d70-feff819cdc9f',
|
'id': 'e82ff8b6-65f0-11e5-9d70-feff819cdc9f',
|
||||||
@ -1343,32 +1372,37 @@ class ShareDriver(object):
|
|||||||
'share_server_id': '07574742-67ea-4dfd-9844-9fbd8ada3d87',
|
'share_server_id': '07574742-67ea-4dfd-9844-9fbd8ada3d87',
|
||||||
'share_server': <models.ShareServer> or None,
|
'share_server': <models.ShareServer> or None,
|
||||||
}
|
}
|
||||||
:param access_rules: A list of access rules that other instances of
|
|
||||||
the share already obey.
|
:param access_rules: A list of access rules
|
||||||
EXAMPLE:
|
These access rules are obeyed by other instances of the share
|
||||||
.. code::
|
|
||||||
[ {
|
Example::
|
||||||
|
|
||||||
|
[
|
||||||
|
{
|
||||||
'id': 'f0875f6f-766b-4865-8b41-cccb4cdf1676',
|
'id': 'f0875f6f-766b-4865-8b41-cccb4cdf1676',
|
||||||
'deleted' = False,
|
'deleted' = False,
|
||||||
'share_id' = 'f0e4bb5e-65f0-11e5-9d70-feff819cdc9f',
|
'share_id' = 'f0e4bb5e-65f0-11e5-9d70-feff819cdc9f',
|
||||||
'access_type' = 'ip',
|
'access_type' = 'ip',
|
||||||
'access_to' = '172.16.20.1',
|
'access_to' = '172.16.20.1',
|
||||||
'access_level' = 'rw',
|
'access_level' = 'rw',
|
||||||
}]
|
}
|
||||||
:param share_server: <models.ShareServer> or None,
|
]
|
||||||
|
|
||||||
|
:param share_server: <models.ShareServer> or None
|
||||||
Share server of the replica to be promoted.
|
Share server of the replica to be promoted.
|
||||||
:return: updated_replica_list or None
|
:return: updated_replica_list or None.
|
||||||
The driver can return the updated list as in the request
|
The driver can return the updated list as in the request
|
||||||
parameter. Changes that will be updated to the Database are:
|
parameter. Changes that will be updated to the Database are:
|
||||||
'export_locations', 'access_rules_status' and 'replica_state'.
|
'export_locations', 'access_rules_status' and 'replica_state'.
|
||||||
:raises Exception
|
:raises: Exception.
|
||||||
This can be any exception derived from BaseException. This is
|
This can be any exception derived from BaseException. This is
|
||||||
re-raised by the manager after some necessary cleanup. If the
|
re-raised by the manager after some necessary cleanup. If the
|
||||||
driver raises an exception during promotion, it is assumed
|
driver raises an exception during promotion, it is assumed that
|
||||||
that all of the replicas of the share are in an inconsistent
|
all of the replicas of the share are in an inconsistent state.
|
||||||
state. Recovery is only possible through the periodic update
|
Recovery is only possible through the periodic update call and/or
|
||||||
call and/or administrator intervention to correct the 'status'
|
administrator intervention to correct the 'status' of the affected
|
||||||
of the affected replicas if they become healthy again.
|
replicas if they become healthy again.
|
||||||
"""
|
"""
|
||||||
raise NotImplementedError()
|
raise NotImplementedError()
|
||||||
|
|
||||||
@ -1377,7 +1411,8 @@ class ShareDriver(object):
|
|||||||
share_server=None):
|
share_server=None):
|
||||||
"""Update the replica_state of a replica.
|
"""Update the replica_state of a replica.
|
||||||
|
|
||||||
NOTE: This call is made on the host which hosts the replica being
|
.. note::
|
||||||
|
This call is made on the host which hosts the replica being
|
||||||
updated.
|
updated.
|
||||||
|
|
||||||
Drivers should fix replication relationships that were broken if
|
Drivers should fix replication relationships that were broken if
|
||||||
@ -1387,11 +1422,11 @@ class ShareDriver(object):
|
|||||||
whenever requested by the administrator through the 'resync' API.
|
whenever requested by the administrator through the 'resync' API.
|
||||||
|
|
||||||
:param context: Current context
|
:param context: Current context
|
||||||
:param replica_list: List of all replicas for a particular share.
|
:param replica_list: List of all replicas for a particular share
|
||||||
This list also contains the replica to be updated. The 'active'
|
This list also contains the replica to be updated. The 'active'
|
||||||
replica will have its 'replica_state' attr set to 'active'.
|
replica will have its 'replica_state' attr set to 'active'.
|
||||||
EXAMPLE:
|
|
||||||
.. code::
|
Example::
|
||||||
|
|
||||||
[
|
[
|
||||||
{
|
{
|
||||||
@ -1420,11 +1455,12 @@ class ShareDriver(object):
|
|||||||
},
|
},
|
||||||
...
|
...
|
||||||
]
|
]
|
||||||
:param replica: Dictionary of the replica being updated.
|
|
||||||
|
:param replica: Dictionary of the replica being updated
|
||||||
Replica state will always be 'in_sync', 'out_of_sync', or 'error'.
|
Replica state will always be 'in_sync', 'out_of_sync', or 'error'.
|
||||||
Replicas in 'active' state will not be passed via this parameter.
|
Replicas in 'active' state will not be passed via this parameter.
|
||||||
EXAMPLE:
|
|
||||||
.. code::
|
Example::
|
||||||
|
|
||||||
{
|
{
|
||||||
'id': 'd487b88d-e428-4230-a465-a800c2cce5f8',
|
'id': 'd487b88d-e428-4230-a465-a800c2cce5f8',
|
||||||
@ -1444,35 +1480,43 @@ class ShareDriver(object):
|
|||||||
'share_network_id': '4ccd5318-65f1-11e5-9d70-feff819cdc9f',
|
'share_network_id': '4ccd5318-65f1-11e5-9d70-feff819cdc9f',
|
||||||
'share_server_id': '4ce78e7b-0ef6-4730-ac2a-fd2defefbd05',
|
'share_server_id': '4ce78e7b-0ef6-4730-ac2a-fd2defefbd05',
|
||||||
}
|
}
|
||||||
:param access_rules: A list of access rules that other replicas of
|
|
||||||
the share already obey. The driver could attempt to sync on any
|
:param access_rules: A list of access rules
|
||||||
un-applied access_rules.
|
These access rules are obeyed by other instances of the share. The
|
||||||
EXAMPLE:
|
driver could attempt to sync on any un-applied access_rules.
|
||||||
.. code::
|
|
||||||
[ {
|
Example::
|
||||||
|
|
||||||
|
[
|
||||||
|
{
|
||||||
'id': 'f0875f6f-766b-4865-8b41-cccb4cdf1676',
|
'id': 'f0875f6f-766b-4865-8b41-cccb4cdf1676',
|
||||||
'deleted' = False,
|
'deleted' = False,
|
||||||
'share_id' = 'f0e4bb5e-65f0-11e5-9d70-feff819cdc9f',
|
'share_id' = 'f0e4bb5e-65f0-11e5-9d70-feff819cdc9f',
|
||||||
'access_type' = 'ip',
|
'access_type' = 'ip',
|
||||||
'access_to' = '172.16.20.1',
|
'access_to' = '172.16.20.1',
|
||||||
'access_level' = 'rw',
|
'access_level' = 'rw',
|
||||||
}]
|
}
|
||||||
:param replica_snapshots: List of dictionaries of snapshot instances
|
]
|
||||||
for each snapshot of the share whose 'aggregate_status' property was
|
|
||||||
reported to be 'available' when the share manager initiated this
|
:param replica_snapshots: List of dictionaries of snapshot instances.
|
||||||
request. Each list member will have two sub dictionaries:
|
This includes snapshot instances of every snapshot of the share
|
||||||
'active_replica_snapshot' and 'share_replica_snapshot'. The 'active'
|
whose 'aggregate_status' property was reported to be 'available'
|
||||||
replica snapshot corresponds to the instance of the snapshot on any
|
when the share manager initiated this request. Each list member
|
||||||
of the 'active' replicas of the share while share_replica_snapshot
|
will have two sub dictionaries: 'active_replica_snapshot' and
|
||||||
corresponds to the snapshot instance for the specific replica being
|
'share_replica_snapshot'. The 'active' replica snapshot corresponds
|
||||||
updated. The driver needs to ensure that this snapshot instance is
|
to the instance of the snapshot on any of the 'active' replicas of
|
||||||
truly available before transitioning from 'out_of_sync' to
|
the share while share_replica_snapshot corresponds to the snapshot
|
||||||
'in_sync'. Snapshots instances for snapshots that have an
|
instance for the specific replica being updated. The driver needs
|
||||||
'aggregate_status' of 'creating' or 'deleting' will be polled for in
|
to ensure that this snapshot instance is truly available before
|
||||||
the update_replicated_snapshot method.
|
transitioning from 'out_of_sync' to 'in_sync'. Snapshots instances
|
||||||
EXAMPLE:
|
for snapshots that have an 'aggregate_status' of 'creating' or
|
||||||
.. code::
|
'deleting' will be polled for in the update_replicated_snapshot
|
||||||
[ {
|
method.
|
||||||
|
|
||||||
|
Example::
|
||||||
|
|
||||||
|
[
|
||||||
|
{
|
||||||
'active_replica_snapshot': {
|
'active_replica_snapshot': {
|
||||||
'id': '8bda791c-7bb6-4e7b-9b64-fefff85ff13e',
|
'id': '8bda791c-7bb6-4e7b-9b64-fefff85ff13e',
|
||||||
'share_instance_id': '10e49c3e-aca9-483b-8c2d-1c337b38d6af',
|
'share_instance_id': '10e49c3e-aca9-483b-8c2d-1c337b38d6af',
|
||||||
@ -1481,18 +1525,19 @@ class ShareDriver(object):
|
|||||||
...
|
...
|
||||||
},
|
},
|
||||||
'share_replica_snapshot': {
|
'share_replica_snapshot': {
|
||||||
'id': ,
|
'id': '10e49c3e-aca9-483b-8c2d-1c337b38d6af',
|
||||||
'share_instance_id': 'd487b88d-e428-4230-a465-a800c2cce5f8',
|
'share_instance_id': 'd487b88d-e428-4230-a465-a800c2cce5f8',
|
||||||
'status': 'creating',
|
'status': 'creating',
|
||||||
'provider_location': None,
|
'provider_location': None,
|
||||||
...
|
...
|
||||||
},
|
},
|
||||||
}]
|
}
|
||||||
|
]
|
||||||
|
|
||||||
:param share_server: <models.ShareServer> or None
|
:param share_server: <models.ShareServer> or None
|
||||||
:return: replica_state
|
:return: replica_state: a str value denoting the replica_state.
|
||||||
replica_state - a str value denoting the replica_state that the
|
Valid values are 'in_sync' and 'out_of_sync' or None (to leave the
|
||||||
replica can have. Valid values are 'in_sync' and 'out_of_sync'
|
current replica_state unchanged).
|
||||||
or None (to leave the current replica_state unchanged).
|
|
||||||
"""
|
"""
|
||||||
raise NotImplementedError()
|
raise NotImplementedError()
|
||||||
|
|
||||||
@ -1501,8 +1546,9 @@ class ShareDriver(object):
|
|||||||
share_server=None):
|
share_server=None):
|
||||||
"""Create a snapshot on active instance and update across the replicas.
|
"""Create a snapshot on active instance and update across the replicas.
|
||||||
|
|
||||||
NOTE: This call is made on the 'active' replica's host. Drivers
|
.. note::
|
||||||
are expected to transfer the snapshot created to the respective
|
This call is made on the 'active' replica's host. Drivers are
|
||||||
|
expected to transfer the snapshot created to the respective
|
||||||
replicas.
|
replicas.
|
||||||
|
|
||||||
The driver is expected to return model updates to the share manager.
|
The driver is expected to return model updates to the share manager.
|
||||||
@ -1512,11 +1558,11 @@ class ShareDriver(object):
|
|||||||
to '100%'.
|
to '100%'.
|
||||||
|
|
||||||
:param context: Current context
|
:param context: Current context
|
||||||
:param replica_list: List of all replicas for a particular share.
|
:param replica_list: List of all replicas for a particular share
|
||||||
The 'active' replica will have its 'replica_state' attr set to
|
The 'active' replica will have its 'replica_state' attr set to
|
||||||
'active'.
|
'active'.
|
||||||
EXAMPLE:
|
|
||||||
.. code::
|
Example::
|
||||||
|
|
||||||
[
|
[
|
||||||
{
|
{
|
||||||
@ -1537,11 +1583,14 @@ class ShareDriver(object):
|
|||||||
},
|
},
|
||||||
...
|
...
|
||||||
]
|
]
|
||||||
:param replica_snapshots: List of all snapshot instances that track
|
|
||||||
the snapshot across the replicas. All the instances will have their
|
:param replica_snapshots: List of dictionaries of snapshot instances.
|
||||||
status attribute set to 'creating'.
|
These snapshot instances track the snapshot across the replicas.
|
||||||
EXAMPLE:
|
All the instances will have their status attribute set to
|
||||||
.. code::
|
'creating'.
|
||||||
|
|
||||||
|
Example::
|
||||||
|
|
||||||
[
|
[
|
||||||
{
|
{
|
||||||
'id': 'd3931a93-3984-421e-a9e7-d9f71895450a',
|
'id': 'd3931a93-3984-421e-a9e7-d9f71895450a',
|
||||||
@ -1559,12 +1608,13 @@ class ShareDriver(object):
|
|||||||
},
|
},
|
||||||
...
|
...
|
||||||
]
|
]
|
||||||
|
|
||||||
:param share_server: <models.ShareServer> or None
|
:param share_server: <models.ShareServer> or None
|
||||||
:return: List of replica_snapshots, a list of dictionaries containing
|
:return: List of dictionaries of snapshot instances.
|
||||||
values that need to be updated on the database for the snapshot
|
The dictionaries can contain values that need to be updated on the
|
||||||
instances being created.
|
database for the snapshot instances being created.
|
||||||
:raises: Exception. Any exception in this method will set all
|
:raises: Exception.
|
||||||
instances to 'error'.
|
Any exception in this method will set all instances to 'error'.
|
||||||
"""
|
"""
|
||||||
raise NotImplementedError()
|
raise NotImplementedError()
|
||||||
|
|
||||||
@ -1572,7 +1622,8 @@ class ShareDriver(object):
|
|||||||
replica_snapshots, share_server=None):
|
replica_snapshots, share_server=None):
|
||||||
"""Delete a snapshot by deleting its instances across the replicas.
|
"""Delete a snapshot by deleting its instances across the replicas.
|
||||||
|
|
||||||
NOTE: This call is made on the 'active' replica's host, since
|
.. note::
|
||||||
|
This call is made on the 'active' replica's host, since
|
||||||
drivers may not be able to delete the snapshot from an individual
|
drivers may not be able to delete the snapshot from an individual
|
||||||
replica.
|
replica.
|
||||||
|
|
||||||
@ -1583,11 +1634,11 @@ class ShareDriver(object):
|
|||||||
from the database.
|
from the database.
|
||||||
|
|
||||||
:param context: Current context
|
:param context: Current context
|
||||||
:param replica_list: List of all replicas for a particular share.
|
:param replica_list: List of all replicas for a particular share
|
||||||
The 'active' replica will have its 'replica_state' attr set to
|
The 'active' replica will have its 'replica_state' attr set to
|
||||||
'active'.
|
'active'.
|
||||||
EXAMPLE:
|
|
||||||
.. code::
|
Example::
|
||||||
|
|
||||||
[
|
[
|
||||||
{
|
{
|
||||||
@ -1608,11 +1659,14 @@ class ShareDriver(object):
|
|||||||
},
|
},
|
||||||
...
|
...
|
||||||
]
|
]
|
||||||
:param replica_snapshots: List of all snapshot instances that track
|
|
||||||
the snapshot across the replicas. All the instances will have their
|
:param replica_snapshots: List of dictionaries of snapshot instances.
|
||||||
status attribute set to 'deleting'.
|
These snapshot instances track the snapshot across the replicas.
|
||||||
EXAMPLE:
|
All the instances will have their status attribute set to
|
||||||
.. code::
|
'deleting'.
|
||||||
|
|
||||||
|
Example::
|
||||||
|
|
||||||
[
|
[
|
||||||
{
|
{
|
||||||
'id': 'd3931a93-3984-421e-a9e7-d9f71895450a',
|
'id': 'd3931a93-3984-421e-a9e7-d9f71895450a',
|
||||||
@ -1630,14 +1684,16 @@ class ShareDriver(object):
|
|||||||
},
|
},
|
||||||
...
|
...
|
||||||
]
|
]
|
||||||
|
|
||||||
:param share_server: <models.ShareServer> or None
|
:param share_server: <models.ShareServer> or None
|
||||||
:return: List of replica_snapshots, a list of dictionaries containing
|
:return: List of dictionaries of snapshot instances.
|
||||||
values that need to be updated on the database for the snapshot
|
The dictionaries can contain values that need to be updated on the
|
||||||
instances being deleted. To confirm the deletion of the snapshot
|
database for the snapshot instances being deleted. To confirm the
|
||||||
instance, set the 'status' attribute of the instance to
|
deletion of the snapshot instance, set the 'status' attribute of
|
||||||
'deleted'(constants.STATUS_DELETED).
|
the instance to 'deleted' (constants.STATUS_DELETED)
|
||||||
:raises: Exception. Any exception in this method will set all
|
:raises: Exception.
|
||||||
instances to 'error_deleting'.
|
Any exception in this method will set the status attribute of all
|
||||||
|
snapshot instances to 'error_deleting'.
|
||||||
"""
|
"""
|
||||||
raise NotImplementedError()
|
raise NotImplementedError()
|
||||||
|
|
||||||
@ -1646,7 +1702,8 @@ class ShareDriver(object):
|
|||||||
replica_snapshot, share_server=None):
|
replica_snapshot, share_server=None):
|
||||||
"""Update the status of a snapshot instance that lives on a replica.
|
"""Update the status of a snapshot instance that lives on a replica.
|
||||||
|
|
||||||
NOTE: For DR and Readable styles of replication, this call is made on
|
.. note::
|
||||||
|
For DR and Readable styles of replication, this call is made on
|
||||||
the replica's host and not the 'active' replica's host.
|
the replica's host and not the 'active' replica's host.
|
||||||
|
|
||||||
This method is called periodically by the share manager. It will
|
This method is called periodically by the share manager. It will
|
||||||
@ -1661,11 +1718,11 @@ class ShareDriver(object):
|
|||||||
instance status to 'error'.
|
instance status to 'error'.
|
||||||
|
|
||||||
:param context: Current context
|
:param context: Current context
|
||||||
:param replica_list: List of all replicas for a particular share.
|
:param replica_list: List of all replicas for a particular share
|
||||||
The 'active' replica will have its 'replica_state' attr set to
|
The 'active' replica will have its 'replica_state' attr set to
|
||||||
'active'.
|
'active'.
|
||||||
EXAMPLE:
|
|
||||||
.. code::
|
Example::
|
||||||
|
|
||||||
[
|
[
|
||||||
{
|
{
|
||||||
@ -1686,11 +1743,13 @@ class ShareDriver(object):
|
|||||||
},
|
},
|
||||||
...
|
...
|
||||||
]
|
]
|
||||||
:param share_replica: Dictionary of the replica the snapshot instance
|
|
||||||
is meant to be associated with. Replicas in 'active' replica_state
|
:param share_replica: Share replica dictionary.
|
||||||
will not be passed via this parameter.
|
This replica is associated with the snapshot instance whose
|
||||||
EXAMPLE:
|
status is being updated. Replicas in 'active' replica_state will
|
||||||
.. code::
|
not be passed via this parameter.
|
||||||
|
|
||||||
|
Example::
|
||||||
|
|
||||||
{
|
{
|
||||||
'id': 'd487b88d-e428-4230-a465-a800c2cce5f8',
|
'id': 'd487b88d-e428-4230-a465-a800c2cce5f8',
|
||||||
@ -1710,11 +1769,13 @@ class ShareDriver(object):
|
|||||||
'share_network_id': '4ccd5318-65f1-11e5-9d70-feff819cdc9f',
|
'share_network_id': '4ccd5318-65f1-11e5-9d70-feff819cdc9f',
|
||||||
'share_server_id': '4ce78e7b-0ef6-4730-ac2a-fd2defefbd05',
|
'share_server_id': '4ce78e7b-0ef6-4730-ac2a-fd2defefbd05',
|
||||||
}
|
}
|
||||||
:param replica_snapshots: List of all snapshot instances that track
|
|
||||||
the snapshot across the replicas. This will include the instance
|
:param replica_snapshots: List of dictionaries of snapshot instances.
|
||||||
being updated as well.
|
These snapshot instances track the snapshot across the replicas.
|
||||||
EXAMPLE:
|
This will include the snapshot instance being updated as well.
|
||||||
.. code::
|
|
||||||
|
Example::
|
||||||
|
|
||||||
[
|
[
|
||||||
{
|
{
|
||||||
'id': 'd3931a93-3984-421e-a9e7-d9f71895450a',
|
'id': 'd3931a93-3984-421e-a9e7-d9f71895450a',
|
||||||
@ -1728,11 +1789,12 @@ class ShareDriver(object):
|
|||||||
},
|
},
|
||||||
...
|
...
|
||||||
]
|
]
|
||||||
:param replica_snapshot: Dictionary of the snapshot instance to be
|
|
||||||
updated. replica_snapshot will be in 'creating' or 'deleting'
|
:param replica_snapshot: Dictionary of the snapshot instance.
|
||||||
states when sent via this parameter.
|
This is the instance to be updated. It will be in 'creating' or
|
||||||
EXAMPLE:
|
'deleting' state when sent via this parameter.
|
||||||
.. code::
|
|
||||||
|
Example::
|
||||||
|
|
||||||
{
|
{
|
||||||
'name': 'share-snapshot-18825630-574f-4912-93bb-af4611ef35a2',
|
'name': 'share-snapshot-18825630-574f-4912-93bb-af4611ef35a2',
|
||||||
@ -1750,12 +1812,14 @@ class ShareDriver(object):
|
|||||||
'deleted_at': None,
|
'deleted_at': None,
|
||||||
'provider_location': None,
|
'provider_location': None,
|
||||||
}
|
}
|
||||||
|
|
||||||
:param share_server: <models.ShareServer> or None
|
:param share_server: <models.ShareServer> or None
|
||||||
:return: replica_snapshot_model_update, a dictionary containing
|
:return: replica_snapshot_model_update: a dictionary.
|
||||||
values that need to be updated on the database for the snapshot
|
The dictionary must contain values that need to be updated on the
|
||||||
instance that represents the snapshot on the replica.
|
database for the snapshot instance that represents the snapshot on
|
||||||
:raises: exception.SnapshotResourceNotFound for
|
the replica.
|
||||||
snapshots that are not found on the backend and their status was
|
:raises: exception.SnapshotResourceNotFound
|
||||||
'deleting'.
|
Raise this exception for snapshots that are not found on the
|
||||||
|
backend and their status was 'deleting'.
|
||||||
"""
|
"""
|
||||||
raise NotImplementedError()
|
raise NotImplementedError()
|
||||||
|
Loading…
x
Reference in New Issue
Block a user