在多个EC2实例中进行应用程序监控

44次阅读
没有评论

问题描述

在运行10个AWS EC2实例,每个实例上运行不同的应用程序。他正在寻找一种应用程序级别的监控解决方案。例如,如果任何实例中的Apache失败,它应该通过日志通知用户。他知道”Nagios”,但它主要用于基础设施监控。有一些用于应用程序监控的工具(如”Monit”),但在每个服务器上手动安装它们是不可能的,特别是当你有多个EC2实例时(最好是一个全局设置,因为实例的数量将不断增加)。

解决方案

请注意以下操作注意版本差异及修改前做好备份。

方案1

对于问题#2,您可以使用配置管理工具(如Chef,Ansible或Puppet)来配置机器。这样,您可以编写一个cookbook,当系统上检测到软件包时,会自动添加一个简单的基于代理的检查。将这些事物编码化可以使其在长期内更易管理。
对于问题#1,您可能正在寻找一种基于代理的监控工具。一些例子包括Prometheus或Sensu,但市面上有无数的选择。这些工具允许您在服务器上描述检查,主服务器只收集给定的任何信息。

方案2

使用脚本或工具来管理容器的启动顺序可能会增加复杂性,并且需要确保容器A和容器B之间的依赖关系正确设置。
另一种方法是编写脚本或使用工具来控制容器的运行顺序。你可以使用docker run命令来手动控制容器的启动顺序,或者使用一些第三方工具来管理容器的依赖关系。

示例:

以下是一个简单的bash脚本示例,可以在容器A启动后启动容器B:

#!/bin/bash
# 启动容器A
docker run -d --name container_a your_image_a
# 等待容器A完全启动
while ! docker exec container_a echo "Container A is ready"; do
  sleep 1
done
# 启动容器B
docker run -d --name container_b your_image_b

在这个示例中,我们首先使用docker run命令启动容器A,并将其命名为container_a。然后,使用一个循环来等待容器A完全启动(这里是通过在容器内运行echo命令来测试)。一旦容器A就绪,我们再使用docker run命令启动容器B,并将其命名为container_b

正文完