将nodejs app部署到Openshift(503错误)

时间:2016-04-06 16:49:31

标签: javascript node.js websocket openshift

将第一个节点js app部署到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)
    ...

但现在在本地工作。

UPDATE2: 我设法切换到一个端口使用。我的错误,现在我将一个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 )
})

它落在服务器监听线上......

UPDATE3: 我已经为服务器的活动添加了eventlistner" listen"并在当地发射。但根据openhift的日志,它没有。 错误仍然相同:

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'

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

1 个答案:

答案 0 :(得分:1)

好吧,我找不到确切的问题,但能够将其本地化。

所以起始应用程序结构是:

  • no express
  • http.server(listen)
  • ws.server(listen)
  • 静态文件服务器(监听)
  • sesh(sessions)

这一切都在当地完美运作。

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

  • 已安装快递
  • 只使用一次听
  • 为什么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”建议:注意中间件的顺序。 会话应该在路由器之前。