首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在运行pm2的nodejs上为docker设置pm2-logrotate?

如何在运行pm2的nodejs上为docker设置pm2-logrotate?
EN

Stack Overflow用户
提问于 2020-06-11 13:43:31
回答 1查看 982关注 0票数 0

我有来自keymetrics/ pm2 :8-jessie的docker镜像,并使用pm2很好地运行了我的nodejs应用程序。我尝试添加pm2-logrotate来调整日志的大小。我在Dockerfile中添加了以下内容。可以启动模块pm2-logrotate,但目标PID为空。有人能帮上忙吗?

代码语言:javascript
复制
FROM keymetrics/pm2:8-jessie

RUN npm install
RUN pm2 install pm2-logrotate
RUN pm2 set pm2-logrotate:retain 90
RUN pm2 set pm2-logrotate:dateFormat YYYY-MM-DD_HH-mm-ss
RUN pm2 set pm2-logrotate:max_size 10M
RUN pm2 set pm2-logrotate:rotateInterval 0 0 * * *
RUN pm2 set pm2-logrotate:rotateModule true
RUN pm2 set pm2-logrotate:workerInterval 10

ENV NODE_ENV=$buildenv
ENV NPM_CONFIG_LOGLEVEL warn

CMD ["sh", "-c", "pm2-runtime start pm2.${NODE_ENV}.config.js"]

pm2 % ls

代码语言:javascript
复制
┌──────────────┬────┬─────────┬─────────┬─────┬────────┬─────────┬────────┬─────┬────────────┬──────┬──────────┐
│ App name     │ id │ version │ mode    │ pid │ status │ restart │ uptime │ cpu │ mem        │ user │ watching │
├──────────────┼────┼─────────┼─────────┼─────┼────────┼─────────┼────────┼─────┼────────────┼──────┼──────────┤
│  app_server  │ 1  │ 1.0.0   │ cluster │ 150 │ online │ 1       │ 2h     │ 0%  │ 104.4 MB   │ root │ disabled │
└──────────────┴────┴─────────┴─────────┴─────┴────────┴─────────┴────────┴─────┴────────────┴──────┴──────────┘
Module
┌───────────────┬────┬─────────┬─────┬────────┬─────────┬─────┬───────────┬──────┐
│ Module        │ id │ version │ pid │ status │ restart │ cpu │ memory    │ user │
├───────────────┼────┼─────────┼─────┼────────┼─────────┼─────┼───────────┼──────┤
│ pm2-logrotate │ 2  │ 2.7.0   │ 205 │ online │ 0       │ 0%  │ 44.5 MB   │ root │
└───────────────┴────┴─────────┴─────┴────────┴─────────┴─────┴───────────┴──────┘
EN

回答 1

Stack Overflow用户

发布于 2020-06-11 15:08:29

一个原因是因为pm2 logrotate不是Docker容器的主进程,而是由pm2管理的进程,所以您可以通过停止定义的主进程来验证此行为,无论pm2-logrotate是否正在运行,您的容器都将死亡。

另外,我不认为它应该是空的,它应该是这样的

代码语言:javascript
复制
pm2 ls
┌─────┬──────────────────┬─────────────┬─────────┬─────────┬──────────┬────────┬──────┬───────────┬──────────┬──────────┬──────────┬──────────┐
│ id  │ name             │ namespace   │ version │ mode    │ pid      │ uptime │ ↺    │ status    │ cpu      │ mem      │ user     │ watching │
├─────┼──────────────────┼─────────────┼─────────┼─────────┼──────────┼────────┼──────┼───────────┼──────────┼──────────┼──────────┼──────────┤
│ 1   │ www              │ default     │ 0.0.0   │ fork    │ 26       │ 13s    │ 0    │ online    │ 0%       │ 40.3mb   │ root     │ disabled │
└─────┴──────────────────┴─────────────┴─────────┴─────────┴──────────┴────────┴──────┴───────────┴──────────┴──────────┴──────────┴──────────┘
Module
┌────┬───────────────────────────────────────┬────────────────────┬───────┬──────────┬──────┬──────────┬──────────┬──────────┐
│ id │ module                                │ version            │ pid   │ status   │ ↺    │ cpu      │ mem      │ user     │
├────┼───────────────────────────────────────┼────────────────────┼───────┼──────────┼──────┼──────────┼──────────┼──────────┤
│ 0  │ pm2-logrotate                         │ 2.7.0              │ 17    │ online   │ 0    │ 0.5%     │ 43.1mb   │ root     │
└────┴───────────────────────────────────────┴────────────────────┴───────┴──────────┴──────┴──────────┴──────────┴──────────┘

也会建议使用高山基础图像,因为上面的图像看起来很重,下面的图像是150MB,而上面的图像大约是1 1GB。

代码语言:javascript
复制
FROM node:alpine
RUN npm install pm2 -g

RUN npm install
RUN pm2 install pm2-logrotate
RUN pm2 set pm2-logrotate:retain 90
RUN pm2 set pm2-logrotate:dateFormat YYYY-MM-DD_HH-mm-ss
RUN pm2 set pm2-logrotate:max_size 10M
RUN pm2 set pm2-logrotate:rotateInterval 0 0 * * *
RUN pm2 set pm2-logrotate:rotateModule true
RUN pm2 set pm2-logrotate:workerInterval 10

ENV NODE_ENV=$buildenv
ENV NPM_CONFIG_LOGLEVEL warn
WORKDIR /app
COPY . /app

CMD ["sh", "-c", "pm2-runtime start confi"]
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/62317830

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档