Merge "[Docs] Make install/usage docs more clear"
This commit is contained in:
commit
4a2056e01f
@ -1,3 +1,5 @@
|
|||||||
|
.. _hardening-domains-label:
|
||||||
|
|
||||||
Hardening Domains
|
Hardening Domains
|
||||||
=================
|
=================
|
||||||
|
|
||||||
|
@ -1,9 +1,11 @@
|
|||||||
Getting started
|
Getting started
|
||||||
===============
|
===============
|
||||||
|
|
||||||
The ansible-hardening role can be used along with the
|
The ansible-hardening role can be used along with the `OpenStack-Ansible`_
|
||||||
`OpenStack-Ansible`_ project or as a standalone role that can be used along
|
project or as a standalone role that can be used along with other Ansible
|
||||||
with other Ansible playbooks.
|
playbooks. This documentation assumes that the reader has completed the steps
|
||||||
|
within the
|
||||||
|
`Ansible installation guide <http://docs.ansible.com/ansible/intro_installation.html>`_.
|
||||||
|
|
||||||
.. _OpenStack-Ansible: https://git.openstack.org/cgit/openstack/openstack-ansible/
|
.. _OpenStack-Ansible: https://git.openstack.org/cgit/openstack/openstack-ansible/
|
||||||
|
|
||||||
@ -11,58 +13,88 @@ with other Ansible playbooks.
|
|||||||
:local:
|
:local:
|
||||||
:backlinks: none
|
:backlinks: none
|
||||||
|
|
||||||
Prepare your system
|
Installing the ansible-hardening role
|
||||||
-------------------
|
-------------------------------------
|
||||||
|
|
||||||
Start by installing ansible and then install the role itself using
|
The recommended installation methods for the ansible-hardening role are
|
||||||
``ansible-galaxy``:
|
``ansible-galaxy`` (recommended) or ``git``.
|
||||||
|
|
||||||
|
Using ``ansible-galaxy``
|
||||||
|
~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
The easiest installation method is to use the ``ansible-galaxy`` command that
|
||||||
|
is provided with your Ansible installation:
|
||||||
|
|
||||||
.. code-block:: console
|
.. code-block:: console
|
||||||
|
|
||||||
pip install ansible
|
ansible-galaxy install git+https://github.com/openstack/ansible-hardening
|
||||||
ansible-galaxy install git+https://git.openstack.org/openstack/ansible-hardening
|
|
||||||
|
|
||||||
The role will be installed into
|
The ``ansible-galaxy`` command will install the role into
|
||||||
``/etc/ansible/roles/ansible-hardening``.
|
``/etc/ansible/roles/ansible-hardening`` and this makes it easy to use with
|
||||||
|
Ansible playbooks.
|
||||||
|
|
||||||
Initial configuration
|
Using ``git``
|
||||||
---------------------
|
~~~~~~~~~~~~~
|
||||||
|
|
||||||
The role's default configuration is suitable for most Linux hosts. Deployers
|
Start by cloning the role into a directory of your choice:
|
||||||
should review the :ref:`special_notes` section to learn more about how to
|
|
||||||
provide custom configuration for the Ansible tasks in the role.
|
|
||||||
|
|
||||||
Using as a standalone role
|
.. code-block:: console
|
||||||
--------------------------
|
|
||||||
|
|
||||||
Adding the ansible-hardening role to existing playbooks is
|
mkdir -p ~/.ansible/roles/
|
||||||
straightforward. Here is an example of an existing role for deploying web
|
git clone https://github.com/openstack/ansible-hardening ~/.ansible/roles/ansible-hardening
|
||||||
servers with the security hardening role added:
|
|
||||||
|
Ansible looks for roles in ``~/.ansible/roles`` by default.
|
||||||
|
|
||||||
|
If the role is cloned into a different directory, that directory must be
|
||||||
|
provided with the ``roles_path`` option in ``ansible.cfg``. The following is
|
||||||
|
an example of a ``ansible.cfg`` file that uses a custom path for roles:
|
||||||
|
|
||||||
|
.. code-block:: ini
|
||||||
|
|
||||||
|
[DEFAULTS]
|
||||||
|
roles_path = /etc/ansible/roles:/home/myuser/custom/roles
|
||||||
|
|
||||||
|
With this configuration, Ansible looks for roles in ``/etc/ansible/roles`` and
|
||||||
|
``~/custom/roles``.
|
||||||
|
|
||||||
|
Usage
|
||||||
|
-----
|
||||||
|
|
||||||
|
The ansible-hardening role works well with existing playbooks. The following
|
||||||
|
is an example of a basic playbook that uses the ansible-hardening role:
|
||||||
|
|
||||||
.. code-block:: yaml
|
.. code-block:: yaml
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
- name: Deploy web servers
|
- name: Harden all systems
|
||||||
hosts: webservers
|
hosts: all
|
||||||
become: yes
|
become: yes
|
||||||
|
vars:
|
||||||
|
security_enable_firewalld: no
|
||||||
|
security_rhel7_initialize_aide: no
|
||||||
|
security_ntp_servers:
|
||||||
|
- 1.example.com
|
||||||
|
- 2.example.com
|
||||||
roles:
|
roles:
|
||||||
- common
|
|
||||||
- webserver
|
|
||||||
- ansible-hardening
|
- ansible-hardening
|
||||||
|
|
||||||
Using with OpenStack-Ansible
|
The variables provided in the ``vars`` section can enable, disable, or alter
|
||||||
----------------------------
|
configuration for various tasks in the ansible-hardening role. For more details
|
||||||
|
on the available variables, refer to the :ref:`hardening-domains_label`
|
||||||
|
section.
|
||||||
|
|
||||||
The ansible-hardening role is automatically enabled and applied in the
|
.. note::
|
||||||
Newton release of OpenStack-Ansible. Set the following Ansible variable to
|
|
||||||
enable the role in the Mitaka release of OpenStack-Ansible:
|
|
||||||
|
|
||||||
.. code-block:: yaml
|
The role must be run as the root user or as a user with ``sudo`` access.
|
||||||
|
The example above uses the ``become`` option, which causes Ansible to use
|
||||||
|
sudo before running tasks. If the role is running as root, this option can
|
||||||
|
be changed to ``user: root``.
|
||||||
|
|
||||||
apply_security_hardening: true
|
.. warning::
|
||||||
|
|
||||||
For more information, refer to the OpenStack-Ansible documentation on
|
It is strongly recommended to run the role in check mode (often called a
|
||||||
`configuring security hardening`_.
|
`dry run`) first before making any modifications. This gives the deployer
|
||||||
|
the opportunity to review all of the proposed changes before applying the
|
||||||
.. _configuring security hardening: http://docs.openstack.org/project-deploy-guide/openstack-ansible/draft/app-advanced-config-security.html#security-hardening
|
role to the system. Use the ``--check`` parameter with ``ansible-playbook``
|
||||||
|
to use check mode.
|
||||||
|
Loading…
Reference in New Issue
Block a user