gpt4 book ai didi

node.js - 如何在 Docker 容器中使用 forever

转载 作者:搜寻专家 更新时间:2023-10-31 22:50:24 25 4
gpt4 key购买 nike

我想在我的 Docker 容器中将我的简单 Node 服务器作为后台进程运行,但是当我尝试使用 forever 启动它时,我得到以下信息:

fs.js:432
return binding.open(pathModule._makeLong(path), stringToFlags(flags), mode);
^
Error: ENOENT, no such file or directory '/.forever/9Spa.log'

所以我尝试在我当前的工作目录中创建一个名为 .forever 的文件夹,但随后我得到了几乎相同的错误(*.log 文件具有不同的正如预期的那样,我每次运行它时都会命名。)

如果我在不使用 forever 的情况下运行我的服务器,它运行良好,没有任何错误。例如:

node server

npm start

两者都可以正常工作,但当然不要在后台运行。

刚运行时出现同样的错误

forever list

所以问题很明显是 forever 而不是我的服务器代码。

npm list -g 显示安装了forever

我在我的 Docker 容器中使用 Ubuntu 14.04.1 LTS 镜像。

我乐于接受建议。

更新

我终于让 forever 运行我在 /home/testuser 中创建一个 .forever 文件夹,并在其中创建一个 pids 文件夹,然后运行以下命令:

forever start -p /home/testuser/.forever --pidFile /home/testuser/.forever/pids/server.pid server.js

根据 the docs

-p PATH Base path for all forever related files (pid files, etc.)

然而,这并不完全正确。我被迫为 --pidFile

指定绝对路径

太棒了,我的服务器正在作为后台进程运行。然而,以下仍然中断:

forever stop server.js

=>
/usr/local/lib/node_modules/forever/lib/forever.js:634
var procs = processes.filter(函数(p){
^
TypeError: Object Error: EACCES, mkdir '/.forever' 没有方法 'filter'
在 Object.forever.findByScript (/usr/local/lib/node_modules/forever/lib/forever.js:634:25)
在/usr/local/lib/node_modules/forever/lib/forever.js:189:20
在/usr/local/lib/node_modules/forever/lib/forever.js:136:14
在/usr/local/lib/node_modules/forever/lib/forever.js:89:20
在/usr/local/lib/node_modules/forever/node_modules/utile/node_modules/mkdirp/index.js:34:29
在/usr/local/lib/node_modules/forever/node_modules/utile/node_modules/mkdirp/index.js:46:53
在 Object.oncomplete (fs.js:107:15)

forever stop -p /home/bit2bit/.forever server.js

同样的结果

forever list

==>
/usr/local/lib/node_modules/forever/lib/forever.js:683
procs.forEach(函数(proc){
^
类型错误:对象错误:EACCES,mkdir '/.forever' 没有方法 'forEach'
在 Object.forever.format (/usr/local/lib/node_modules/forever/lib/forever.js:683:11)
在/usr/local/lib/node_modules/forever/lib/forever.js:520:28
在/usr/local/lib/node_modules/forever/lib/forever.js:136:14
在/usr/local/lib/node_modules/forever/lib/forever.js:89:20
在/usr/local/lib/node_modules/forever/node_modules/utile/node_modules/mkdirp/index.js:34:29
在/usr/local/lib/node_modules/forever/node_modules/utile/node_modules/mkdirp/index.js:46:53
在 Object.oncomplete (fs.js:107:15)

因此,虽然我现在可以启动我的服务器,但我无法再次停止它。

最佳答案

Where does forever store console.log output?

尝试添加一个 -o 参数来指定日志输出到的位置。

关于node.js - 如何在 Docker 容器中使用 forever,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25267360/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com