我们讨论的 Docker 容器包括 sysdig、consul、fluentd、mesos-slave 等,我们几乎在所有机器上运行它们。
目前我们正在使用 Ubuntu 的 Upstart 和 CoreOS 的 Fleetctl。我们正在迁移到 Ubuntu 18.04 LTS,目前正在考虑是否将配置转换为:
- Systemd 或
- Docker-compose
Systemd 可以进行健康检查并自动恢复已停止运行的进程。它也与我们大量使用的 Upstart 最为相似。我们的 Upstart 配置文件由 cloud-config 生成,如下所示:
- >
/usr/local/bin/generate-docker-upstart fluentd registry/fluentd:1.0.1
-e HOST=elasticsearch
-e PORT=9200
-e INDEX=fluentd
-e NODE=`hostname -s`
-e ROLE=app
-e ENVIRONMENT={{Ref:Environment}}
-e TENANT={{Ref:Tenant}}
-p 24224:24224
--name \$NAME \$IMAGE
我们使用 AWS CloudFormation 使虚拟机上线。
我们不能使用真正的容器编排框架(我们已经使用 Marathon/Mesos),因为这些服务必须在每个主机上运行,并且在 Marathon/Mesos 运行之前运行。
哪种解决方案最有意义?尽管已经在 Mesos 上使用 Marathon,但将这些文件转换为 systemd 还是开始使用 docker-compose?