如何在一个 Docker 容器中运行多个进程 ?

在容器化的世界里,Docker 彻底改变了开发人员构建、发布和运行应用程序的方式。Docker 容器封装了运行应用程序所需的所有依赖项,使其易于跨不同环境一致地部署。然而,在单个 Docker 容器中管理多个进程可能具有挑战性,这就是 Supervisor 发挥作用的地方。

什么是 Supervisor ?

Supervisor 是一个 client/server 系统,允许其用户监视和控制类 Unix 操作系统上的多个进程。特别是

对于管理多个需要同时运行的复杂应用程序特别有用。Supervisor 提供了一种强大而可靠的方式确保进程的启动、停止和重启。

如何管理多进程 ?

Docker 容器被设计为运行单个进程。虽然可以使用 systemd 或 init 等工具在容器中运行多个进程,但这违背了 Docker 的基本设计原则。此外,手动管理这些流程可能很麻烦,而且容易出错。

一种常见方法是在 Docker 容器中运行一个类似 Supervisor 的进程管理器。Supervisor 作为看门狗,确保所有必要的进程都在运行,并在它们失败时重新启动它们。

如何集成 Docker 和 Supervisor ?

将 Supervisor 与 Docker 集成很简单。你可以直接在 Docker 容器中安装 Supervisor,也可以创建一个单独的容器来运行 Supervisor。下面是一个如何在 Docker 中使用 Supervisor 的基本步骤。

(1) 创建 Supervisor 配置文件

定义 supervisord.conf 配置文件,指定要管理的进程。文件放在 Supervisor 可以在容器中访问的位置。

(2) 安装 Supervisor

如果你要创建一个单独的 Supervisor 容器,你需要将 Supervisor 作为 Dockerfile 的一部分来安装。您可以使用 apt 或 yum 之类的包管理器来安装 Supervisor 和任何依赖项。

(3) 启动 Supervisor

安装 Supervisor 之后,您可以手动启动它,也可以将其作为容器启动过程的一部分启动。Supervisor 将读取配置文件并开始监视指定的进程。

(4) 运行应用程序

最后,在 Docker 容器中启动应用程序。Supervisor 将确保所有必要的程序都在运行,并处理发生的故障。

实践示例

(1) 克隆存储库到您的本地机器

git clone https://github.com/tecrahul/docker-supervisor.git

(2) 切换到克隆的存储库目录

cd docker-supervisor

(3) 构建 Docker 镜像

docker build -t docker-supervisor .

(4) 运行 Docker 容器

docker run -d -p 80:80 docker-supervisor

现在,Docker 容器已经运行, Apache 和 PHP-FPM 的运行由 Supervisor 管理。您可以在浏览器中访问 http://localhost 使用 Apache Web 提供的服务。

我的开源项目

相关推荐
北京_宏哥几秒前
《手把手教你》系列基础篇(九十二)-java+ selenium自动化测试-框架设计基础-POM设计模式简介(详解教程)
java·selenium·前端工程化
当归102411 分钟前
微服务与消息队列RabbitMQ
java·微服务
Lx35212 分钟前
《从头开始学java,一天一个知识点》之:循环结构:for与while循环的使用场景
java·后端
Cache技术分享17 分钟前
15. Java 如何声明一个变量来引用数组
java·前端
雷渊17 分钟前
深入分析理解mysql的MVCC
java·数据库·面试
知其然亦知其所以然18 分钟前
Java 高级面试题:Lock 到底比 synchronized 强在哪?
java·后端·面试
风象南20 分钟前
Spring Boot 的 20个实用技巧
java·spring boot
Java陈序员21 分钟前
IDEA 必备插件!轻松搞定 JSON 格式化!
java·json·intellij idea
Anarkh_Lee21 分钟前
图解JVM - 13.垃圾回收器
java·jvm·后端
sakoba42 分钟前
spring IOC(实现原理)
java·开发语言