2016-09-01 20:52:57 +02:00
|
|
|
<a id="Service-apply-for-example"></a>Working with Apply for rules - tcp ports example
|
|
|
|
==============================================
|
|
|
|
|
|
|
|
This example wants to show you how to make use of `Apply For` rule for services.
|
|
|
|
|
|
|
|
First you need to define a `tcp_ports` data field of type `Array` assigned to a `Host Template`.
|
|
|
|
Refer to [Working with fields](14-Fields-example-interfaces-array.md) section to setup a data field.
|
|
|
|
You also need to define a `tcp_port` data field of type `String`, we will associate it to a
|
|
|
|
`Service Template` later.
|
|
|
|
|
2017-03-19 20:37:06 +01:00
|
|
|
Then, please go to the `Dashboard` and choose the `Monitored services` dashlet:
|
2016-09-01 20:52:57 +02:00
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/2cfe5/2cfe5cbfe81de8fff6618b758dc08393e8f93d97" alt="Dashboard - Monitored services"
|
|
|
|
|
|
|
|
Then create a new `Service template` with check command `tcp`:
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/d1da7/d1da78234b566529b4bf7147520d9ecbed57a7b5" alt="Define service template - tcp"
|
|
|
|
|
|
|
|
Then associate the data field `tcp_port` to this `Service template`:
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/5350b/5350b67d88ee656639987e5f4a8bffb0c3227f8a" alt="Associate field to service template - tcp_port"
|
|
|
|
|
|
|
|
Then create a new `apply-rule` for the `Service template`:
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/f432e/f432e0bc0ce83b3481c8b053366e13a454dd0fb5" alt="Define apply rule"
|
|
|
|
|
|
|
|
Now define the `Apply For` property, select the previously defined field `tcp_ports` associated to
|
2016-09-09 00:37:23 +02:00
|
|
|
the host template. `Apply For` rule define a variable `config` that can be used as `$config$`, it
|
|
|
|
corresponds to the item of the array it will iterate on.
|
|
|
|
|
|
|
|
Set the `Tcp port` property to `$config$`:
|
2016-09-01 20:52:57 +02:00
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/dc4c7/dc4c73e36d7d2955bf2ccb5acf2ee9fa69e6a45b" alt="Add field to template"
|
|
|
|
|
|
|
|
(Side note: if you can't see your `tcp_ports` property in `Apply For` dropdown, try to create one
|
|
|
|
host with a non-empty `tcp_ports` value.)
|
|
|
|
|
|
|
|
That's it, now all your hosts defining a `tcp_ports` variable will be assigned the `Tcp Check`
|
|
|
|
service.
|
|
|
|
|
|
|
|
Have a look at the config preview, it will show you how `Apply For` services will look like once
|
|
|
|
deployed:
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/08ae0/08ae07929f4ce13c4db0aa7a49b25c754e0008dd" alt="Host config preview with Array"
|