【发布时间】:2018-10-01 16:42:11
【问题描述】:
我正在尝试在 Azure 应用服务 (Linux) 上运行最简单的 node.js 应用,但我不知道如何运行它。我一直在尝试不同的方法,但似乎没有任何效果。
我只是通过 FTP 部署应用程序并将文件放在“wwwroot”下,但是当请求 url 时,它会永远加载,然后以服务不可用响应结束。
在创建应用程序时,我选择 Linux 作为平台,运行时 node.js 8.11 并通过“代码”而不是 docker 进行部署。
在日志中我可以看到:
docker run -d -p 46852:8080 --name [appname] -e WEBSITE_NODE_DEFAULT_VERSION=8.11 -e APPSETTING_WEBSITE_NODE_DEFAULT_VERSION=8.11 -e WEBSITE_SITE_NAME=[appname] -e WEBSITE_AUTH_ENABLED=False -e WEBSITE_ROLE_INSTANCE_ID=0 -e WEBSITE_INSTANCE_ID=[id] -e HTTP_LOGGING_ENABLED=1 appsvc/node:8.11.2_1805212105
Container [appname] for site [appname] did not start within expected time limit. Elapsed time = 230.4882261 sec
这是什么意思,即使我通过“代码”和 FTP 设置了应用程序部署,docker 还是被以某种方式使用。
package.json
{
"name": "foo",
"version": "1.0.0",
"description": "x",
"author": "x",
"private": true,
"scripts": {
"start": "node server.js"
},
"dependencies": {
"express": "^4.16.3"
}
}
server.js
const express = require('express')
const app = express()
const port = process.env.PORT || 3000
const host = process.env.HOST || '127.0.0.1'
app.get('/', (req, res) => res.send('Hello!'))
app.listen(port, host)
我还尝试通过 ssh 进入应用程序并运行 npm install。我尝试通过 ssh 控制台 node server.js 运行该应用程序,但最终得到消息“端口已在使用中”。我尝试在 Azure 门户的“应用程序设置”中将端口设置为 8080。
我在这里缺少什么?如何让应用运行?
【问题讨论】:
标签: node.js azure azure-web-app-service