1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91
|
..
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.
.. _tutorial-policies:
=====================
Working with Policies
=====================
Creating a Policy
~~~~~~~~~~~~~~~~~
A policy contains the set of rules that are checked/enforced before or
after certain cluster operations are performed. The detailed specification
of a specific policy type is provided as the ``spec`` of a policy object
when it is created. The following is a sample ``spec`` for a deletion policy:
.. literalinclude:: ../../../examples/policies/deletion_policy.yaml
:language: yaml
.. note::
The above source file can be found in senlin source tree at
``/examples/policies/deletion_policy.yaml``.
To create a policy object using this specification (``spec`` for short):
.. code-block:: console
$ cd $SENLIN_ROOT/examples/policies
$ openstack cluster policy create --spec-file deletion_policy.yaml dp01
To verify the policy creation, you can do:
.. code-block:: console
$ openstack cluster policy list
$ openstack cluster policy show dp01
Attaching a Policy
~~~~~~~~~~~~~~~~~~
The enforce a policy on a cluster, attach a policy to it:
.. code-block:: console
$ openstack cluster policy attach --policy dp01 mycluster
To verify the policy attach operation, do the following:
.. code-block:: console
$ openstack cluster policy binding list mycluster
$ openstack cluster policy binding show --policy dp01 mycluster
Verifying a Policy
~~~~~~~~~~~~~~~~~~
To verify the deletion policy attached to the cluster ``mycluster``, you
can try expanding the cluster, followed by shrinking it:
.. code-block:: console
$ openstack cluster members list mycluster
$ openstack cluster expand mycluster
$ openstack cluster members list mycluster
$ openstack cluster shrink mycluster
$ openstack cluster members list mycluster
After the scale-in operation is completed, you will find that the oldest
node from the cluster is removed. If you want to remove the youngest node
instead, you can create a different deletion policy with a different
specification.
For more details about policy types and policy management, check the
:doc:`Policy Types <../user/policy_types>` section and the
:doc:`Policies <../user/policies>` section in the
:ref:`user-references` documentation respectively.
You may also want to check the
:doc:`Cluster-Policy Bindings <../user/bindings>` section in the
:ref:`user-references` section for more details on managing the cluster-policy
relationship.
|