81 lines
3.1 KiB
Markdown
81 lines
3.1 KiB
Markdown
<a id="Working-with-agents"></a>Working with Agents and Config Zones
|
|
====================================================================
|
|
|
|
Working with Icinga 2 Agents can be quite tricky, as each Agent needs
|
|
its own Endpoint and Zone definition, correct parent, peering host and
|
|
log settings. There may always be reasons for a completely custom-made
|
|
configuration. I'd however strongly suggest to give the Director-assisted
|
|
variant at least a try first. It might safe you a lot of headaches.
|
|
|
|
|
|
Preparation
|
|
-----------
|
|
|
|
Agent settings are not available for modification directly on a host
|
|
object. This requires you to create an "Icinga Agent" template. You
|
|
could name it exactly like that, it's important to use meaningful names
|
|
for your templates.
|
|
|
|
data:image/s3,"s3://crabby-images/38000/38000f6ae7e36e9985c7f447ff7dc96193aaecdd" alt="Create an Agent template"
|
|
|
|
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
|
|
the correct template and you're all done.
|
|
|
|
|
|
Usage
|
|
-----
|
|
|
|
Well, create a host, choose an Agent template, that's it:
|
|
|
|
data:image/s3,"s3://crabby-images/3e55f/3e55ff7d6afcf9986c190f1b3572e2ab885b7c90" alt="Create an Agent-based host"
|
|
|
|
Once you import the "Icinga Agent" template you'll see a new "Agent" tab.
|
|
It tries to assist you with the initial Agent setup by showing a sample
|
|
config:
|
|
|
|
data:image/s3,"s3://crabby-images/42a7f/42a7f7a726e3504f6c1c84ad282f6347cdfa0d80" alt="Agent instructions 1"
|
|
|
|
data:image/s3,"s3://crabby-images/eb82c/eb82c984b4d5e2f0fbc0b8591612e79c9710860e" 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/71ca6/71ca6129f9b7a8b9032a73cc52985cf3f5b8114d" alt="Agent preview"
|
|
|
|
|
|
Create Agent-based services
|
|
---------------------------
|
|
|
|
Similar game for services that should run on your Agents. First create a
|
|
template with a meaningful name and define that Services inheriting from
|
|
this template should run on your Agents.
|
|
|
|
data:image/s3,"s3://crabby-images/fa78b/fa78bb32673ba695d77d8c2afaa5ba99c28439fd" 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
|
|
on your Agents ist importing that template:
|
|
|
|
data:image/s3,"s3://crabby-images/27bba/27bba179bd5da57625af476d29e2672795e8bee3" alt="Agent-based load check"
|
|
|
|
Config preview shows that everything works as expected:
|
|
|
|
data:image/s3,"s3://crabby-images/f5063/f50638a7e52a1b3a0d8083e406470f3692f7a183" 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/522cd/522cd927a4f2ddbd62514aa76b4714353fec498c" alt="Agent-based service assigned to host template"
|
|
|
|
While a service added to a host template are implicitely rendered as
|
|
assign rules, you could of course also use your `Agent-based service`
|
|
template in custom apply rules:
|
|
|
|
data:image/s3,"s3://crabby-images/63379/633794a4702a23fc36d5709ef56f1d4e3b43d68d" alt="Agent-based service applied"
|
|
|
|
|
|
|