如何解决使用 pm2 和 npm run
我有一个 react frontendapp,我在 package.json 中为它定义了许多构建和运行任务,如下面的代码片段所示:
"scripts": {
"start": "env-cmd -f .env.dev react-scripts start","build": "react-scripts build","test": "react-scripts test","eject": "react-scripts eject","build:dev": "env-cmd -f .env.dev npm run build","build:test": "env-cmd -f .env.test npm run build","build:prep": "env-cmd -f .env.prep npm run build","build:prod": "env-cmd -f .env.prod npm run build","start-dev-server": "env-cmd -f .env.dev node server/server.js","start-test-server": "env-cmd -f .env.test node server/server.js","start-prep-server": "env-cmd -f .env.prep node server/server.js","start-server": "env-cmd -f .env.prod node server/server.js"
},
我的目标是使用基于应该执行“npm run start-server”的运行配置的 pm2 工具来运行应用程序。此执行应在内部运行上述代码段中的最后一行,即“env-cmd -f .env.prod node server/server.js”
我写了一个 pm2 配置文件,即 my_config.json,用于实现上述场景如下:
my_config.json:
{
"apps": [
{
"name": "ReactFrontEndApp","script": "npm","args": "run start-server"
}
]
}
最后,我在命令控制台中发出以下命令:
pm2 start my_config.json
当发出上述 pm2 命令时,我的应用程序列在 pm2 list 命令输出下。尽管如此,pm2工具也开始一个接一个地弹出命令控制台,没有尽头(前一个消失,然后下一个出现)。我同时在浏览器中的 https://localhost:3000 上测试了我的应用程序,但浏览器根本没有带来任何我的应用程序(即未找到)。因此,我必须使用 pm2 stop 命令停止我的应用程序。
问题: my_config.json 文件中是否有我可能遗漏的内容,这可能会导致此连续命令控制台打开?可能有什么问题?
解决方法
我猜你的服务器以某种方式加载失败,也许 pm2 更改了相关的环境变量。
C:\\Script\\locale\\en
的输出是什么?当您手动运行 pm2 logs 0
时发生了什么?手动运行 npm run start-server
时发生了什么?
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。