【发布时间】:2021-12-18 06:21:51
【问题描述】:
我在 linux AMI EC2 实例上有一个节点应用程序,我想用 systemd 运行它。我用 npm start 命令编写了一个 bash 脚本,但是当我用 systemd 运行它时,日志告诉我找不到 npm 命令:
Nov 03 21:22:45 ip-10-85-147-43.ec2.internal systemd[1]: Started NodeApp.
Nov 03 21:22:45 ip-10-85-147-43.ec2.internal systemd[1]: Starting NodeApp...
Nov 03 21:22:45 ip-10-85-147-43.ec2.internal start.sh[9609]: /home/ec2-user/source/NodeApp/start.sh: line 8: npm: command not found
Nov 03 21:22:45 ip-10-85-147-43.ec2.internal systemd[1]: NodeApp.service: main process exited, code=exited, status=127/n/a
Nov 03 21:22:45 ip-10-85-147-43.ec2.internal systemd[1]: Unit NodeApp.service entered failed state.
Nov 03 21:22:45 ip-10-85-147-43.ec2.internal systemd[1]: NodeApp.service failed.
当我运行 npm -v 时,它显示 7.4.0。
这是我的 bash 脚本:
#! /bin/bash
cd home/ec2-user/source/NodeApp/
npm start
以及NodeApp.service的内容
[Unit]
Description= Node app
[Service]
ExecStart=/home/ec2-user/source/NodeApp/start.sh
[Install]
WantedBy=multi-user.target
【问题讨论】:
-
使用shell脚本的原因是什么?只需使用
WorkingDirectory=/home/ec2-user/source/NodeApp/和ExecStart=/full/path/to/npm start -
@jordanm 我只是按照你的方式尝试过,它说找不到命令,即使使用 npm 命令的完整路径也是如此
标签: node.js linux bash amazon-ec2 systemd