blob: 29690d5bbe471b7d4399f954baa28086f7c4ed04 [file] [log] [blame]
===============
Reclass Formula
===============
reclass is an "external node classifier" (ENC) as can be used with automation
tools, such as Puppet, Salt, and Ansible. It is also a stand-alone tool for
merging data sources recursively.
Sample Metadata
===============
Install sources from [repository, git, pip]
.. code-block:: yaml
salt:
source:
engine: pkg
...
source:
engine: git
repo: git+https://github.com/salt-formulas/reclass
branch: master
...
source:
engine: pip
...
If reclass is pre-installed, set the engine to None to avoid updates.
.. code-block:: yaml
salt:
source:
engine: None
Reclass storage with data fetched from git
.. literalinclude:: tests/pillar/storage_git.sls
:language: yaml
Reclass storage with local data source
.. literalinclude:: tests/pillar/storage_local.sls
:language: yaml
Reclass storage with archive data source
.. literalinclude:: tests/pillar/storage_archive.sls
:language: yaml
Reclass storage with archive data source with content hash check
.. literalinclude:: tests/pillar/storage_archive_public.sls
:language: yaml
Reclass model with single node definition
.. literalinclude:: tests/pillar/generate_single.sls
:language: yaml
Reclass model with multiple node defined
.. literalinclude:: tests/pillar/generate_multi.sls
:language: yaml
Reclass model with multiple node defined and interpolation enabled
.. literalinclude:: tests/pillar/generate_multi_interpolate.sls
:language: yaml
Reclass storage with simple class mappings
.. literalinclude:: tests/pillar/class_mapping.sls
:language: yaml
Reclass models with dynamic node classification
.. literalinclude:: tests/pillar/node_classify.sls
:language: yaml
Classify node after creation and unclassify on node deletion
.. code-block:: yaml
salt:
master:
reactor:
reclass/minion/classify:
- salt://reclass/reactor/node_register.sls
reclass/minion/declassify:
- salt://reclass/reactor/node_unregister.sls
Event to trigger the node classification
.. code-block:: bash
salt-call event.send 'reclass/minion/classify' "{'node_master_ip': '$config_host', 'node_ip': '${node_ip}', 'node_domain': '$node_domain', 'node_cluster': '$node_cluster', 'node_hostname': '$node_hostname', 'node_os': '$node_os'}"
.. note::
You can send any parameters in the event payload, all will be checked
against dynamic node classification conditions.
Both actions will use the minion ID as the node_name to be updated.
Event to trigger the node declassification
.. code-block:: bash
salt-call event.send 'reclass/minion/declassify'
Nodes definitions generator
===========================
Generate nodes definitions by running:
.. code-block:: bash
salt-call state.sls reclass.storage -l debug
Remove unnecessary files from nodes/_generated:
.. code-block:: yaml
reclass:
storage:
reclass_nodes_cleanup: true
Static node definition:
.. code-block:: yaml
reclass:
storage:
enabled: true
node:
openstack_benchmark_node01:
classes:
- cluster.example.openstack.benchmark
domain: example.com
name: bmk01
params:
linux_system_codename: xenial
salt_master_host: 192.168.0.253
single_address: 192.168.2.95
Multiple nodes definitions (using generator):
.. code-block:: yaml
reclass:
storage:
enabled: true
node:
openstack_compute_rack01:
classes:
- cluster.example.openstack.compute
domain: example.com
name: cmp<<count>>
params:
linux_system_codename: xenial
salt_master_host: 192.168.0.253
repeat:
start: 1
count: 50
digits: 3
params:
single_address:
start: 101
value: 192.168.2.<<count>>
Multiple nodes definitions (using generator) with IP address comprehension. Ranges are named and formatting symbol of the same name is replaced by IP address from corresponding range:
.. code-block:: yaml
reclass:
storage:
enabled: true
node:
openstack_compute_rack01:
classes:
- cluster.example.openstack.compute
domain: example.com
name: cmp<<count>>
params:
linux_system_codename: xenial
salt_master_host: 192.168.0.253
repeat:
ip_ranges:
single_address: '172.16.10.97-172.16.10.98'
tenant_address: '172.16.20.97-172.16.20.98'
start: 1
count: 50
digits: 3
params:
single_address:
start: 101
value: 192.168.2.<<single_address>>
tenant_address:
start: 101
value: 192.168.2.<<tenant_address>>
More Information
================
* http://reclass.pantsfullofunix.net/index.html
* http://reclass.pantsfullofunix.net/operations.html
Documentation and Bugs
======================
To learn how to install and update salt-formulas, consult the documentation
available online at:
http://salt-formulas.readthedocs.io/
In the unfortunate event that bugs are discovered, they should be reported to
the appropriate issue tracker. Use Github issue tracker for specific salt
formula:
https://github.com/salt-formulas/salt-formula-reclass/issues
For feature requests, bug reports or blueprints affecting entire ecosystem,
use Launchpad salt-formulas project:
https://launchpad.net/salt-formulas
You can also join salt-formulas-users team and subscribe to mailing list:
https://launchpad.net/~salt-formulas-users
Developers wishing to work on the salt-formulas projects should always base
their work on master branch and submit pull request against specific formula.
https://github.com/salt-formulas/salt-formula-reclass
Any questions or feedback is always welcome so feel free to join our IRC
channel:
#salt-formulas @ irc.freenode.net