2016-04-13 16:10:08 +02:00
|
|
|
<a id="Working-with-agents"></a>Working with Agents and Config Zones
|
|
|
|
====================================================================
|
2016-04-12 09:33:17 +02:00
|
|
|
|
|
|
|
Working with Icinga 2 Agents can be quite tricky, as each Agent needs
|
2016-07-21 17:43:57 +02:00
|
|
|
its own Endpoint and Zone definition, correct parent, peering host and
|
2016-04-12 09:33:17 +02:00
|
|
|
log settings. There may always be reasons for a completely custom-made
|
2016-10-20 02:49:09 +02:00
|
|
|
configuration. However, I'd strongly suggest to give the Director-assisted
|
|
|
|
variant at least a try first. It might save you a lot of headaches.
|
2016-04-12 09:33:17 +02:00
|
|
|
|
2016-04-17 18:20:20 +02:00
|
|
|
|
2016-04-12 09:33:17 +02:00
|
|
|
Preparation
|
|
|
|
-----------
|
|
|
|
|
|
|
|
Agent settings are not available for modification directly on a host
|
|
|
|
object. This requires you to create an "Icinga Agent" template. You
|
2016-10-20 02:49:09 +02:00
|
|
|
could name it exactly like that; it's important to use meaningful names
|
2016-04-12 09:33:17 +02:00
|
|
|
for your templates.
|
|
|
|
|
2016-04-17 18:20:20 +02:00
|
|
|
data:image/s3,"s3://crabby-images/6b603/6b603549b93e980f3ed91bdb686a7a9eee3a6176" alt="Create an Agent template"
|
|
|
|
|
2016-10-20 02:49:09 +02:00
|
|
|
As long as you're not using Satellite nodes, a single Agent zone is all
|
|
|
|
you need. Otherwise, you should create one Agent template per satellite
|
|
|
|
zone. If you want to move an Agent to a specific zone, just assign it
|
2016-04-12 09:33:17 +02:00
|
|
|
the correct template and you're all done.
|
|
|
|
|
|
|
|
|
|
|
|
Usage
|
|
|
|
-----
|
|
|
|
|
2016-04-17 18:20:20 +02:00
|
|
|
Well, create a host, choose an Agent template, that's it:
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/2971e/2971e12efcbb6a88a34e2380aec52824c4578e06" alt="Create an Agent-based host"
|
|
|
|
|
2016-10-20 02:49:09 +02:00
|
|
|
Once you import the "Icinga Agent" template, you'll see a new "Agent" tab.
|
2016-04-12 09:33:17 +02:00
|
|
|
It tries to assist you with the initial Agent setup by showing a sample
|
2016-04-17 18:20:20 +02:00
|
|
|
config:
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/e0020/e0020f5568c088e086a3ec2e68338d71f0bd6653" alt="Agent instructions 1"
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/d0865/d086519bf320ac21cee9c724e848c7ed29c7dd1c" alt="Agent instructions 2"
|
|
|
|
|
|
|
|
The preview shows that the Icinga Director would deploy multiple objects
|
|
|
|
for your newly created host:
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/a8809/a8809ccb5eda87791d9386eb923257ca6bf9fccf" alt="Agent preview"
|
|
|
|
|
|
|
|
|
|
|
|
Create Agent-based services
|
|
|
|
---------------------------
|
|
|
|
|
2016-10-20 02:49:09 +02:00
|
|
|
Similar game for services that should run on your Agents. First, create a
|
|
|
|
template with a meaningful name. Then, define that Services inheriting from
|
2016-04-17 18:20:20 +02:00
|
|
|
this template should run on your Agents.
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/d12a5/d12a5cef9bcc29a7b8598d2178c5bc22aa7ab955" alt="Agent-based service"
|
|
|
|
|
|
|
|
Please do not set a cluster zone, as this would rarely be necessary.
|
|
|
|
Agent-based services will always be deployed to their Agent's zone by
|
|
|
|
default. All you need to do now for services that should be executed
|
2016-10-20 02:49:09 +02:00
|
|
|
on your Agents is importing that template:
|
2016-04-17 18:20:20 +02:00
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/7e255/7e2555e98cf4936f8fe95813f678fa353d3656ae" alt="Agent-based load check"
|
|
|
|
|
|
|
|
Config preview shows that everything works as expected:
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/7f3ac/7f3ac206e4639147e15b15780f8fc71856ba2117" alt="Agent-based service preview"
|
|
|
|
|
|
|
|
It's perfectly valid to assign services to host templates. Look how the
|
|
|
|
generated config differs now:
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/b0d5a/b0d5a7759ea97d31f628183703ed59853a0d7b1a" alt="Agent-based service assigned to host template"
|
|
|
|
|
2016-10-20 02:49:09 +02:00
|
|
|
While services added to a host template are implicitly rendered as
|
2016-04-17 18:20:20 +02:00
|
|
|
assign rules, you could of course also use your `Agent-based service`
|
|
|
|
template in custom apply rules:
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/0e7da/0e7da3d9e58cd9b2e8ac42779d6e94a9b17da58e" alt="Agent-based service applied"
|
|
|
|
|
|
|
|
|
|
|
|
|