我正在尝试像这样在AWS cloudformation用户数据中运行npm start:
nodejs = '\n', \
'echo "starting node server" > /tmp/nodejs.log\n', \
'npm run start-dev --prefix /data/app/myProject >> /tmp/nodejs.log &\n', \
'echo "After starting node server" >> /tmp/nodejs.log', \
'\n' ''
稍后将其与其他命令一起放入用户数据中。
这是执行后我在/tmp/nodejs.log中得到的内容:
starting node server
After starting node server
npm run命令不会留下任何日志,并且服务器也不会启动。如果我在终端中运行该命令,则服务器将成功运行。
为什么不执行npm-start命令?
关注
服务器无法启动的原因是,在userdata脚本中无法识别npm命令。但是,我要通过nvm在打包程序配置程序脚本中安装节点:
{
"type": "shell",
"script": "sh/install_node.sh",
"execute_command": "chmod +x {{ .Path }}; sudo bash -c '{{ .Vars }} {{ .Path }}'"
}
这是install_node.sh文件:
#!/usr/bin/env bash
#install nvm
curl -o- https://raw.githubusercontent.com/creationix/nvm/v0.34.0/install.sh | bash
export NVM_DIR="$HOME/.nvm"
[ -s "$NVM_DIR/nvm.sh" ] && \. "$NVM_DIR/nvm.sh" # This loads nvm
[ -s "$NVM_DIR/bash_completion" ] && \. "$NVM_DIR/bash_completion" # This loads nvm bash_completion
#install node
nvm install 6.8.0
所以现在我想弄清楚为什么通过打包程序配置程序脚本安装节点不足以使apm cloudformation userdata脚本中识别npm。
答案 0 :(得分:1)
如果有人偶然发现了这个问题,解决方案是将节点路径简单地添加到cloudFormation中的PATH环境变量中,如下所示:
nodejs = '\n', \
'PATH=/root/.nvm/versions/node/v6.8.0/bin:$PATH\n', \
'npm run start-dev --prefix path/to/project\n' \
'\n' ''