如何创建一个可抢占的Docker容器

42次阅读
没有评论

问题描述

想要创建一个可抢占的Docker容器,即在一段时间后自动停止,并在收到请求时重新启动。他希望能够像Google Compute Engine的可抢占实例或Heroku的免费Dyno一样,当没有活动1小时后进入休眠状态,并在收到请求时重新唤醒。
需要注意的是,用户有一个Docker Compose项目,他希望为其中一个服务设置生命周期,该服务还依赖于其他服务。他的项目中还有一个独立运行的traefik容器,用于处理请求并将其发送到其他容器。所以他想知道是否有类似于request_post_hook的机制,可以在收到请求时启动已停止的docker-compose容器。

解决方案

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

方案1

目前没有直接的方法可以实现这一需求,但可以通过运行一个中间件容器来实现。你可以考虑使用其中一个“Serverless”平台。如果你的用例适用于这种模型,许多Docker/Swarm/Kubernetes Serverless工具可以实现你的需求,但你需要运行其他容器来管理它。建议先浏览一下OpenFAAS文档,看看它是否适合你的需求。

方案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

正文完