配置 Heartbeat 监控器
编辑配置 Heartbeat 监控器编辑
要配置 Heartbeat,请定义一组 monitors
来检查您的远程主机。在 heartbeat.yml
配置文件内或 heartbeat.config.monitors.path
所引用的目录中的外部动态加载文件中指定监控器。使用外部文件的优势之一是,这些文件可以自动重新加载,而无需停止 Heartbeat 进程。
每个 monitor
项目都是 yaml 列表中的一个条目,因此以一个破折号 (-) 开头。您可以定义要使用的监控器类型、要检查的主机以及控制 Heartbeat 行为的其他可选设置。
以下示例使用 icmp
、tcp
和 http
协议直接在 heartbeat.yml
文件中配置三个监控器,并演示如何使用 TCP 回显和 HTTP 响应验证
# heartbeat.yml heartbeat.monitors: - type: icmp id: ping-myhost name: My Host Ping hosts: ["myhost"] schedule: '*/5 * * * * * *' - type: tcp id: myhost-tcp-echo name: My Host TCP Echo hosts: ["myhost:777"] # default TCP Echo Protocol check.send: "Check" check.receive: "Check" schedule: '@every 5s' - type: http id: service-status name: Service Status service.name: my-apm-service-name hosts: ["https://127.0.0.1:80/service/status"] check.response.status: [200] schedule: '@every 5s' heartbeat.scheduler: limit: 10
使用 heartbeat.yml
配置文件很方便,但有两个缺点:当监控器数量很多时,它可能难以管理,并且当其内容发生变化时,它不会自动重新加载 heartbeat。
通过 heartbeat.config.monitors
定义监控器,以防止这些问题发生。为此,您的 heartbeat.yml
文件将包含以下内容
# heartbeat.yml heartbeat.config.monitors: # Directory + glob pattern to search for configuration files path: /path/to/my/monitors.d/*.yml # If enabled, heartbeat will periodically check the config.monitors path for changes reload.enabled: true # How often to check for changes reload.period: 1s
然后,在 heartbeat.config.monitors.path
指向的目录中定义一个或多个文件。如果需要,您可以在给定文件中指定多个监控器。这些文件的内容仅为监控器定义,例如通常在 heartbeat.yml
的 heartbeat.monitors
部分中的内容。以下是一个示例
# /path/to/my/monitors.d/localhost_service_check.yml - type: http id: service-status name: Service Status hosts: ["https://127.0.0.1:80/service/status"] check.response.status: [200] schedule: '@every 5s'
监控器类型编辑
您可以配置 Heartbeat 使用以下监控器类型
tcp
和 http
监控器类型都支持 SSL/TLS 和一些代理设置。
正在寻找浏览器监控选项? Heartbeat 浏览器检查处于测试阶段,永远不会公开提供。
如果您想设置浏览器检查,我们强烈建议使用 项目 或 Kibana 中的 Synthetics 应用程序 通过 Synthetics 来创建和管理浏览器监控器。
如果您需要参考以前如何设置测试版 Heartbeat 浏览器检查,请参阅 8.7 的浏览器选项文档.