将nodejs应用程序部署到Openshift(503错误)

有一个问题部署第一个节点js应用程序openshift。

我有点困惑与港口。

我在创build服务器时设置了这个:

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 ) }) 

我已经logging了端口。 我收到8080.但是,如果我想听websockets我也必须手动设置为8080(接收),我相信,这导致我错误,听同一端口两次。

读取日志也certificate,该应用程序落在ws服务器上的创build方法。 我敢打赌,哪里的港口是这个原因。 但是,如何解决?

有什么select,我还看不到?

更新:更改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) ... 

但现在在当地工作。

Update2:我设法切换到一个端口的使用。 我的错误,现在我传递一个http服务器作为参数的websocket服务器的创build方法。 仍然在当地工作。 现在的代码是:

 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 ) }) 

它落在服务器监听线上…

Update3:我已经添加了eventlist的服务器事件“聆听”,并在本地触发。 但根据loginopenshift它不。 错误仍然是一样的:

 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' 

我没有想法。 感谢任何帮助。 谢谢,最好的问候。

那么,我不能find确切的问题,但能够本地化。

所以开始的应用程序结构是:

  • 没有expression
  • http.server(听)
  • ws.server(听)
  • 静态文件服务器(听)
  • sesh(会话)

这一切都在本地完美工作。

对于openshift部署,我必须做这些更改,才能正常开始工作:

  • 安装快递
  • 只使用一个听
  • 为什么sesh模块没有为我工作,我已经转换到“快速会话”

最后的代码看起来像这样(希望有人会觉得这有用):

 '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”的build议:要注意中间件的顺序。 会话应该在路由器之前。