如何在一个 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 提供的服务。

我的开源项目

相关推荐
老魏爱学习4 分钟前
Apache Commons Collections 反序列化漏洞
java·学习·web安全
binishuaio20 分钟前
java 实训第12天 (git版本控制继续)
java·开发语言·git
咕噜Yuki060925 分钟前
Java基础篇:学会这些技能,程序员职场竞争力UP UP
java·开发语言·编程语言
Hdnw28 分钟前
Java异常体系结构
java·开发语言·error
seasugar33 分钟前
Maven
java·maven
y打伞的鱼y44 分钟前
小张求职记五
java·面试
行者Sun19891 小时前
【K8s】专题十五(1):Kubernetes 网络之概念总览
网络·云原生·容器·kubernetes
q567315231 小时前
Python 中的字符串匹配算法
android·java·javascript·python·算法
hummhumm1 小时前
Oracle 第20章:数据库调优
java·数据库·后端·python·mysql·oracle·database
WANT_如初2 小时前
Nacos集群搭建
java·springcloud·nacos集群