Docker 与 PM2:Node.js 服务部署的自动重启策略比较

在容器化技术日益普及的今天,Docker 已成为部署 Node.js 服务的常用选择。

同时,PM2 作为一个进程管理工具,也常被用于管理 Node.js 进程。

两者都提供了进程崩溃时的自动重启功能。

docker 重启

写个 dockerfile:

dockerfile 复制代码
FROM node:18-alpine

WORKDIR /app

COPY ./index.js .

CMD ["node", "/app/index.js"]

写如下代码:

打包镜像:

dockerfile 复制代码
docker build -t restart-test:v1.0 .

运行镜像:

dockerfile 复制代码
docker run -d --name=restart-test-container restart-test:v1.0

1s 之后,容器就停掉了。

我们可以在 docker run 的时候通过 --restart 指定重启策略:

bash 复制代码
docker run -d --restart=always --name=restart-test-container2 restart-test:v1.0

always 总是尝试重启容器。

打印了很多次错误日志:

你可以点击停止,就不会再重启了。

--restart 还有一些参数:

  1. no:这是默认的重启策略。当容器退出时,不会尝试重启它。
  2. on-failure::仅在容器非正常退出时自动重启。可以指定重启次数,如 on-failure:3 表示最多重启三次。
  3. unless-stopped:除非手动停止,否则容器总是自动重启。与 always 类似,但区别在于当 Docker 守护进程重启时,unless-stopped 策略的容器不会自动重启。

pm2 重启

新建 pm2.Dockerfile:

dockerfile 复制代码
FROM node:18-alpine

WORKDIR /app

COPY ./index.js .

RUN npm install -g pm2

CMD ["pm2-runtime", "/app/index.js"]

然后 build 一下,生成镜像:

bash 复制代码
docker build -t restart-test:v2.0 -f pm2.Dockerfile .

然后跑一下:

bash 复制代码
docker run -d --name=restart-test-container3 restart-test:v2.0

这时候会发现容器一直是运行状态,但是内部的进程一直在重启:

也就是说,Docker 的自动重启功能和 PM2 的自动重启功能是重合的。

选择哪个重启

在大多数情况下,使用 Docker 的自动重启功能已经足够满足需求,无需再使用 PM2。特别是当使用容器编排工具(如Kubernetes)时,更倾向于让容器编排工具来管理容器的重启和调度。

如果只是 Docker 部署,可以考虑结合 pm2 来做进程的重启,可能会更快点。

docker compose 配置 restart

Docker Compose 是用于同时跑多个 Docker 容器的,它自然也支持 restart 的配置:

相关推荐
计算机小手3 分钟前
高效 P2P 文件传输工具:FileSync 利用 WebRTC 技术实现极速安全传输
经验分享·docker·webrtc·开源软件
じòぴé南冸じょうげん8 分钟前
小程序的project.private.config.json是无依赖文件,那可以删除吗?
前端·小程序·json
会豪17 分钟前
Electron主进程渲染进程如何优雅的进行通信
前端
jianghaha201118 分钟前
前端 Word 模板参入特定数据 并且下载
前端·word
跟橙姐学代码18 分钟前
轻松搞定 Python 模块与包导入:新手也能秒懂的入门指南
前端·python·ipython
aiwery23 分钟前
大模型场景下的推送技术选型:轮询 vs WebSocket vs SSE
前端·agent
会豪25 分钟前
前端插件-不固定高度的DIV如何增加transition
前端
却尘25 分钟前
Server Actions 深度剖析(2):缓存管理与重新验证,如何用一行代码干掉整个客户端状态层
前端·客户端·next.js
小菜全25 分钟前
Vue 3 + TypeScript 事件触发与数据绑定方法
前端·javascript·vue.js
Hilaku29 分钟前
面试官开始问我AI了,前端的危机真的来了吗?
前端·javascript·面试