我试图在aws cloudformation用户数据中运行npm,如下所示:
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' ''这将与其他命令一起放在userdata中。
下面是执行后我在/tmp/nodejs.log中得到的内容:
starting node server
After starting node servernpm命令不会留下任何日志,服务器也不会启动。如果我在终端中运行该命令,那么服务器将成功运行。
为什么npm命令没有被执行?
跟踪
服务器没有启动的原因是由于在userdata脚本中未识别出npm命令。不过,我正在通过nvm在packer提供程序脚本中安装节点:
{
"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因此,现在我试图弄清楚为什么通过packer提供程序脚本安装节点不足以让npm在脚本中被识别。
发布于 2019-02-20 11:18:39
如果有人遇到这个问题,解决方案就是简单地将节点路径添加到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' ''https://stackoverflow.com/questions/54655256
复制相似问题