我在 VirtualBox 内的 ubuntu 14.04.3 上有 icinga 2.3.11。我试图在此处监视“https”端口 443,例如“ https://mail.google.com ”。以下是我的默认 host.conf 文件片段
object Host "mailserver-01" {
import "generic-host"
address = "74.125.136.17" /* ip for mail.google.com */
vars.os = "Linux"
vars.http_vhosts["http"] = {
http_uri = "/"
}
vars.http_ssl = "1"
vars.http_warn_time = "5"
vars.http_critical_time = "10"
vars.notification["mail"] = {
groups = [ "icingaadmins" ]
}
}
下面是来自默认 services.conf 文件的片段
apply Service "httpS" {
import "generic-service"
check_command = "http"
assign where host.name == "mailserver-01"
}
虽然 icingaweb2 仪表板显示 OK/green,但我不确定它是否正确
您的主机将自定义属性“http_vhosts”定义为字典,但从未使用过(没有适用于定义迭代该字典和生成服务对象的规则)。
相反,服务应用规则(没有 for 循环)只应用服务“httpS”。无意中设置了主机自定义属性“http_ssl” - 它应该将true读取为布尔值而不是数字作为字符串(这始终是正确的)。
您可能想要检查多个 URI,而不仅仅是 /。
我的建议(2 个解决方案):
1) 修复您的服务应用规则并从您的主机对象定义中删除 http_* 自定义属性。而是将它们添加到服务应用规则中:
您可以在文档中找到用作http CheckCommand 命令参数的所有自定义属性:http ://docs.icinga.org/icinga2/latest/doc/module/icinga2/chapter/plugin-check-commands#plugin-check-命令-http
2)改用服务申请规则并遍历主机上定义的 http_vhosts 字典。
注意这里的命名:“https /”将是生成的服务名称。http_ssl 和 http_uri 与 http CheckCommand 所需的自定义属性的名称完全相同。
魔法发生在 apply for 规则中:字典键将是服务名称。字典值是一个嵌套字典,包含 http_uri 和 http_ssl 作为键。在名为“config”的示例中。该配置字典具有与“vars”属性完全相同的结构,这就是为什么我们可以将其添加到服务申请定义中。
使用icinga2 daemon -C验证配置,然后查看生成的服务对象以查看生成了哪些自定义属性(icinga2 对象列表)。
一件好事 - 定义了 http_vhosts 自定义属性的所有主机都将生成这些服务对象,不需要 extea“分配位置”表达式(也许宁可添加忽略位置以用于异常)。使用正确的策略,您只需编写一次应用规则,并且以后只添加具有匹配自定义属性字典的新主机 :-)
http://docs.icinga.org/icinga2/latest/doc/module/icinga2/chapter/monitoring-basics#using-apply-for
虽然解决方案 2) 需要有关 icinga 2 配置语言及其关键字、值类型和魔术技巧的高级知识。然而,我们认为这些方法和最佳实践有助于减少采用和更改文件的长期维护。
您还可以更进一步,根据主机名对不同的 threshokd 使用 if-else 条件。例如,或者使用函数来定义基于时间段的动态阈值。
我用谷歌搜索并找到了 http 命令
在这个例子中,我试图监控https://mail.google.com 下面是 /etc/icinga2/conf.d/hosts.conf
这是 icingaweb2 仪表板上的样子
示例 2