代码部署 ApplicationStart 卡在使用节点挂起

Gre*_*nby 4 amazon-web-services node.js aws-code-deploy

嗨,我是使用 Code Deploy 的新手。我正在尝试启动一个节点应用程序。我的根目录中有 setup.sh、start.sh 和 app.js。

这是我的 appspec.yml 文件

version: 0.0
os: linux
files:
 - source: /
   destination: /
hooks:
  Install:
    - location: setup.sh
      timeout: 3600
  ApplicationStart:
    - location: start.sh
      timeout: 3600
Run Code Online (Sandbox Code Playgroud)

设置文件

yum -y install nodejs npm --enablerepo=epel
npm install
Run Code Online (Sandbox Code Playgroud)

启动文件

node /app.js
Run Code Online (Sandbox Code Playgroud)

app.js(只是一个基本的虚拟服务器)

var express = require("express");
var app = express();

app.get("/",function(req,res) {
    res.send("Hello world")
})


var server = app.listen(8080,function() {
    console.log("Listening at " + server.address().address + ": " + server.address().port);
});
Run Code Online (Sandbox Code Playgroud)

安装步骤成功完成,但代码部署在执行 ApplicationStart 步骤时卡在挂起状态。

我很确定这是因为 app.js 程序持续运行,那么 CodeDeploy 应该如何知道它正在运行并继续运行?

Jon*_*pie 5

CodeDeploy 代理正在等待它启动的脚本返回退出代码并关闭stdoutstderr。要在后台启动进程并将其与主机代理分离以便它可以作为守护进程运行,请尝试:

node /app.js > /dev/null 2> /dev/null < /dev/null &
Run Code Online (Sandbox Code Playgroud)

注意:您需要修改您的程序以写入日志文件而不是控制台,因为守护程序通常没有要写入的控制台(就像在这个版本中一样)。

在此处查看官方文档:http : //docs.aws.amazon.com/codedeploy/latest/userguide/troubleshooting.html#troubleshooting-long-running-processes