将 nodejs 应用程序部署到 Openshift(503 错误)
Deploying nodejs app to Openshift (503 error)
将第一个节点 js 应用程序部署到 openshift 时出现问题。
我对端口有点困惑。
我在创建服务器时设置了这个:
var port = process.env.OPENSHIFT_NODEJS_PORT || 8080,
server_ip_address = process.env.OPENSHIFT_NODEJS_IP || '127.0.0.1'
http.createServer(function (request, response) {
return router(request, response);
}).listen(port, server_ip_address, function() {
console.log( "Listening on " + server_ip_address + ", server_port " + port )
})
我已经登录了端口。我收到 8080。但是,如果我想收听 websockets,我也必须手动设置为 8080(在接收时),我相信,这会导致我出错,收听同一个端口两次。
阅读日志也证明,该应用程序落在了 ws 服务器创建方法上。我敢打赌,港口就是原因。但是,如何解决?
有没有我还看不到的选项?
更新:
把websocket端口改成8000,报错好像是一样的:
Error: listen EACCES
at errnoException (net.js:905:11)
at Server._listen2 (net.js:1024:19)
at listen (net.js:1065:10)
at Server.listen (net.js:1139:5)
...
但现在可以在本地使用了。
更新2:
我已经设法切换到一个端口的使用。我的错误,现在我将一个 http 服务器作为参数传递给 websocket 服务器创建方法。还在本地工作。
当前代码:
var port = process.env.OPENSHIFT_NODEJS_PORT || 8080,
server_ip_address = process.env.OPENSHIFT_NODEJS_IP || '127.0.0.1'
var server = http.createServer(function (request, response) {
return router(request, response);
})
server.listen(port, server_ip_address, function() {
console.log( "Listening on " + server_ip_address + ", server_port " + port )
})
它落在服务器侦听线上...
更新3:
我为服务器的事件 "listening" 添加了 eventlistner 并在本地触发。但根据 openshift 上的日志,它没有。
错误还是一样:
Error: listen EACCES
at errnoException (net.js:905:11)
at Server._listen2 (net.js:1024:19)
at listen (net.js:1065:10)
at Server.listen (net.js:1139:5)
at Server.server.listen (/var/lib/openshift/56fc344f2d5271249e0000fe/app-root/runtime/repo/node_modules/sesh/lib/core.js:56:12)
at Object.<anonymous> (/var/lib/openshift/56fc344f2d5271249e0000fe/app-root/runtime/repo/server.js:18:15)
at Module._compile (module.js:456:26)
at Object.Module._extensions..js (module.js:474:10)
at Module.load (module.js:356:32)
at Function.Module._load (module.js:312:12)
DEBUG: Program node server.js exited with code 8
DEBUG: Starting child process with 'node server.js'
我没主意了。感谢任何帮助。
谢谢,致以最诚挚的问候。
好吧,我找不到确切的问题,但可以定位它。
所以开始的应用程序结构是:
- 没有快递
- http.server(听)
- ws.server(听)
- 静态文件服务器(监听)
- sesh(会话)
这一切都在本地完美运行。
对于 openshift 部署,我必须进行这些更改才能开始正常工作:
- 安装快递
- 只用一个listen
- 为什么 sesh 模块对我不起作用,我已经切换到 'express-session'
最终代码如下所示(希望有人会觉得这有用):
'use strict';
var http = require('http'),
express = require('express'),
app = express()
var router = require('./modules/router')
var session = require('express-session')
app.use(session({
secret: 'two keyboard cats',
resave: false,
saveUninitialized: true,
cookie: { secure: true }
}));
app.use(router)
app.use(express.static('public'))
var port = process.env.OPENSHIFT_NODEJS_PORT || 8080,
server_ip_address = process.env.OPENSHIFT_NODEJS_IP || '127.0.0.1'
var server = http.createServer(app)
server.listen(port, server_ip_address, function() {
console.log("listening to the server")
})
路由器模块是这样的:
'use strict';
var router = require('express').Router();
router.get('/', function(req, res) {
console.log(req.session.id)
res.writeHead(302, { 'Location': '/index.html' })
res.end()
})
module.exports = router
还有像我这样"noobs"的建议:注意中间件的顺序。
会话应该在路由器之前进行。
将第一个节点 js 应用程序部署到 openshift 时出现问题。
我对端口有点困惑。
我在创建服务器时设置了这个:
var port = process.env.OPENSHIFT_NODEJS_PORT || 8080,
server_ip_address = process.env.OPENSHIFT_NODEJS_IP || '127.0.0.1'
http.createServer(function (request, response) {
return router(request, response);
}).listen(port, server_ip_address, function() {
console.log( "Listening on " + server_ip_address + ", server_port " + port )
})
我已经登录了端口。我收到 8080。但是,如果我想收听 websockets,我也必须手动设置为 8080(在接收时),我相信,这会导致我出错,收听同一个端口两次。
阅读日志也证明,该应用程序落在了 ws 服务器创建方法上。我敢打赌,港口就是原因。但是,如何解决?
有没有我还看不到的选项?
更新: 把websocket端口改成8000,报错好像是一样的:
Error: listen EACCES
at errnoException (net.js:905:11)
at Server._listen2 (net.js:1024:19)
at listen (net.js:1065:10)
at Server.listen (net.js:1139:5)
...
但现在可以在本地使用了。
更新2: 我已经设法切换到一个端口的使用。我的错误,现在我将一个 http 服务器作为参数传递给 websocket 服务器创建方法。还在本地工作。 当前代码:
var port = process.env.OPENSHIFT_NODEJS_PORT || 8080,
server_ip_address = process.env.OPENSHIFT_NODEJS_IP || '127.0.0.1'
var server = http.createServer(function (request, response) {
return router(request, response);
})
server.listen(port, server_ip_address, function() {
console.log( "Listening on " + server_ip_address + ", server_port " + port )
})
它落在服务器侦听线上...
更新3: 我为服务器的事件 "listening" 添加了 eventlistner 并在本地触发。但根据 openshift 上的日志,它没有。 错误还是一样:
Error: listen EACCES
at errnoException (net.js:905:11)
at Server._listen2 (net.js:1024:19)
at listen (net.js:1065:10)
at Server.listen (net.js:1139:5)
at Server.server.listen (/var/lib/openshift/56fc344f2d5271249e0000fe/app-root/runtime/repo/node_modules/sesh/lib/core.js:56:12)
at Object.<anonymous> (/var/lib/openshift/56fc344f2d5271249e0000fe/app-root/runtime/repo/server.js:18:15)
at Module._compile (module.js:456:26)
at Object.Module._extensions..js (module.js:474:10)
at Module.load (module.js:356:32)
at Function.Module._load (module.js:312:12)
DEBUG: Program node server.js exited with code 8
DEBUG: Starting child process with 'node server.js'
我没主意了。感谢任何帮助。 谢谢,致以最诚挚的问候。
好吧,我找不到确切的问题,但可以定位它。
所以开始的应用程序结构是:
- 没有快递
- http.server(听)
- ws.server(听)
- 静态文件服务器(监听)
- sesh(会话)
这一切都在本地完美运行。
对于 openshift 部署,我必须进行这些更改才能开始正常工作:
- 安装快递
- 只用一个listen
- 为什么 sesh 模块对我不起作用,我已经切换到 'express-session'
最终代码如下所示(希望有人会觉得这有用):
'use strict';
var http = require('http'),
express = require('express'),
app = express()
var router = require('./modules/router')
var session = require('express-session')
app.use(session({
secret: 'two keyboard cats',
resave: false,
saveUninitialized: true,
cookie: { secure: true }
}));
app.use(router)
app.use(express.static('public'))
var port = process.env.OPENSHIFT_NODEJS_PORT || 8080,
server_ip_address = process.env.OPENSHIFT_NODEJS_IP || '127.0.0.1'
var server = http.createServer(app)
server.listen(port, server_ip_address, function() {
console.log("listening to the server")
})
路由器模块是这样的:
'use strict';
var router = require('express').Router();
router.get('/', function(req, res) {
console.log(req.session.id)
res.writeHead(302, { 'Location': '/index.html' })
res.end()
})
module.exports = router
还有像我这样"noobs"的建议:注意中间件的顺序。 会话应该在路由器之前进行。