2016-05-02 10:58:05 +02:00
|
|
|
<a id="Automation"></a>Automation - Configuration management
|
2016-06-23 17:09:06 +02:00
|
|
|
============================================================
|
2016-02-25 11:44:44 +01:00
|
|
|
|
|
|
|
Director has been designed to work in distributed environments. In case
|
|
|
|
you're using tools like Puppet, Ansible, Salt (R)?ex or similar, this
|
|
|
|
chapter is what you're looking for!
|
|
|
|
|
|
|
|
Generic hints
|
|
|
|
-------------
|
|
|
|
|
2016-07-21 17:43:57 +02:00
|
|
|
Director keeps all of its configuration in a relational database. So,
|
2016-02-25 11:44:44 +01:00
|
|
|
all you need to tell him is how it can reach and access that db. In case
|
|
|
|
you already rolled out Icinga Web 2 you should already be used to handle
|
|
|
|
resource definitions.
|
|
|
|
|
2016-08-19 13:33:22 +02:00
|
|
|
The Director needs a `database resource`, and your RDBMS must either by
|
2016-02-25 11:44:44 +01:00
|
|
|
MySQL, MariaDB or PostgreSQL. This is how such a resource could look like
|
|
|
|
in your `/etc/icingaweb2/resources.ini`:
|
|
|
|
|
|
|
|
```ini
|
|
|
|
[Director DB]
|
|
|
|
type = "db"
|
|
|
|
db = "mysql"
|
|
|
|
host = "localhost"
|
|
|
|
dbname = "director"
|
|
|
|
username = "director"
|
|
|
|
password = "***"
|
|
|
|
charset = "utf8"
|
|
|
|
```
|
|
|
|
|
|
|
|
Please note that the charset is required and MUST be `utf8`.
|
|
|
|
|
|
|
|
Next you need to tell the Director to use this database resource. Create
|
2016-07-21 17:43:57 +02:00
|
|
|
its `config.ini` with the only required setting:
|
2016-02-25 11:44:44 +01:00
|
|
|
|
|
|
|
```ini
|
|
|
|
[db]
|
|
|
|
resource = "Director DB"
|
|
|
|
```
|
|
|
|
|
|
|
|
Hint: `/etc/icingaweb2/modules/director/config.ini` is usually the full
|
|
|
|
path to this config file.
|
|
|
|
|
2016-04-12 21:13:35 +02:00
|
|
|
#### Schema creation and migrations
|
2016-02-25 11:44:44 +01:00
|
|
|
|
|
|
|
You do not need to manually care about creating the schema and to migrate
|
|
|
|
it for newer versions. Just `grant` the configured user all permissions on
|
|
|
|
his database.
|
|
|
|
|
|
|
|
On CLI then please run:
|
|
|
|
|
|
|
|
icingacli director migration run --verbose
|
|
|
|
|
|
|
|
You should run this command after each upgrade, or you could also run it
|
|
|
|
at a regular interval. Please have a look at...
|
|
|
|
|
|
|
|
icingacli director migration pending --verbose
|
|
|
|
|
|
|
|
...in case you are looking for an idempotent way of managing the schema.
|
|
|
|
Use `--help` to learn more about those commands.
|
|
|
|
|
|
|
|
If you have any good reason for doing so and feel experienced enough you
|
|
|
|
can of course also manage the schema on your own. All required files are
|
|
|
|
to be found in our `schema` directories.
|
|
|
|
|
|
|
|
|
|
|
|
Deploy Icinga Director with Puppet
|
|
|
|
----------------------------------
|
|
|
|
|
|
|
|
Drop the director source repository to a directory named `director` in
|
|
|
|
one of your `module_path`'s and enable the module as you did with all the
|
|
|
|
others.
|
|
|
|
|
|
|
|
Deploy the mentioned database resource and `config.ini`. Director could
|
|
|
|
now be configured and kick-started via the web frontend. But you are here
|
|
|
|
for automation, so please read on.
|
|
|
|
|
|
|
|
### Handle schema migrations
|
|
|
|
|
|
|
|
It doesn't matter whether you already have a schema, did a fresh install
|
|
|
|
or just an upgrade. Migrations are as easy as defining:
|
|
|
|
|
|
|
|
exec { 'Icinga Director DB migration':
|
|
|
|
path => '/usr/local/bin:/usr/bin:/bin',
|
|
|
|
command => 'icingacli director migration run',
|
|
|
|
onlyif => 'icingacli director migration pending',
|
|
|
|
}
|
|
|
|
|
|
|
|
Hint: please do not travel back in time, schema downgrades are not
|
|
|
|
supported.
|
|
|
|
|
|
|
|
### Kickstart an empty Director database
|
|
|
|
|
|
|
|
The Director kickstart wizard helps you with setting up a connection to
|
2016-07-21 17:43:57 +02:00
|
|
|
Icinga2 master node, import its endpoint and zone definition and it also
|
2016-02-25 11:44:44 +01:00
|
|
|
syncs already configured command definitions. But this wizard is not only
|
|
|
|
available through the web frontend, you can perfectly trigger it in an
|
|
|
|
idempotent way with Puppet:
|
|
|
|
|
|
|
|
exec { 'Icinga Director Kickstart':
|
|
|
|
path => '/usr/local/bin:/usr/bin:/bin',
|
|
|
|
command => 'icingacli director kickstart run',
|
|
|
|
onlyif => 'icingacli director kickstart required',
|
|
|
|
require => Exec['Icinga Director DB migration'],
|
|
|
|
}
|
|
|
|
|
|
|
|
Nothing will happen so far. Kickstart will not do anything unless you
|
|
|
|
drop a `kickstart.ini` allowing the CLI kickstart helper to do so:
|
|
|
|
|
|
|
|
```ini
|
|
|
|
[config]
|
|
|
|
endpoint = icinga-master
|
|
|
|
; host = 127.0.0.1
|
|
|
|
; port = 5665
|
|
|
|
username = director
|
|
|
|
password = ***
|
|
|
|
```
|
|
|
|
|
2016-03-03 13:30:58 +01:00
|
|
|
Usually `/etc/icingaweb2/modules/director/kickstart.ini` should be the
|
2016-02-25 11:44:44 +01:00
|
|
|
full path to this file. `endpoint` (master certificate name), `username`
|
|
|
|
and `password` (fitting an already configured `ApiUser`) are required.
|
|
|
|
`host` can be a resolvable hostname or an IP address. `port` is 5665 per
|
|
|
|
default in case none is given. And of course your Icinga2 installation
|
|
|
|
needs to have a corresponding `ApiListener` (look at your enabled
|
|
|
|
features) listening at the given port.
|
|
|
|
|
2016-03-24 00:18:41 +01:00
|
|
|
You can run the `kickstart` from the CLI if you don't use a tool for
|
|
|
|
automation.
|
|
|
|
|
|
|
|
icingacli director kickstart run
|
|
|
|
|
|
|
|
You can rerun the kickstart if you have to reimport changed local
|
|
|
|
config, even when the beforementioned check tells you you don't need to.
|
|
|
|
Or you could use the import/synchronisation features of Director.
|