Openshift总是为Node.js应用程序提供503错误

时间:2015-02-24 18:50:54

标签: javascript node.js express openshift server

我正在尝试使用Openshift的免费服务设置我的第一个Node.js + express网络应用程序。

我在我的计算机上安装了node + npm和openshift工具,并尝试运行我的应用程序。在我的本地机器上一切正常,但在我将项目推送到Openshift网站后,它总是会出现'503 Service Unavailable'错误。

我尝试rhc app restart -a firstapp,但它没有解决问题。我还检查了package.json,这是正确的。

这是我的代码:

var express = require('express');
var app = express();
var fs      = require('fs');
var parser  = require('body-parser');

//Setup ip adress and port
var ipaddress ;

function initIPAdress() {
    var adr = process.env.OPENSHIFT_NODEJS_IP;
    if (typeof adr === "undefined") {
            //  Log errors on OpenShift but continue w/ 127.0.0.1 - this
            //  allows us to run/test the app locally.
            console.warn('No OPENSHIFT_NODEJS_IP var, using localhost');
            adr = 'localhost';
    }

    ipaddress = adr;
}

var port      = process.env.OPENSHIFT_NODEJS_PORT || 8080;


app.get('/', function (req, res) {
  res.send('Hello World!')
})

app.get('/admin', function (req, res) {
        res.setHeader('Content-Type', 'text/html'); 
        res.send( fs.readFileSync('./index_admin.html') );
})

app.listen(port, ipaddress, function() {
        initIPAdress();//Call setup ip adress
        console.log('%s: Node server started on %s:%d ...',
                        Date(Date.now() ), ipaddress, port);
});

1 个答案:

答案 0 :(得分:1)

问题是,在app.listen方法之后,IP地址设置不正确。所以,我必须按如下方式更改我的代码:

var express = require('express');
var app = express();
var fs      = require('fs');
var parser  = require('body-parser');

//Setup ip adress and port
var ipaddress ;

function initIPAdress() {
    var adr = process.env.OPENSHIFT_NODEJS_IP;
    if (typeof adr === "undefined") {
            //  Log errors on OpenShift but continue w/ 127.0.0.1 - this
            //  allows us to run/test the app locally.
            console.warn('No OPENSHIFT_NODEJS_IP var, using localhost');
            adr = 'localhost';
    }

    ipaddress = adr;
}

var port      = process.env.OPENSHIFT_NODEJS_PORT || 8080;


app.get('/', function (req, res) {
  res.send('Hello World!')
})

app.get('/admin', function (req, res) {
        res.setHeader('Content-Type', 'text/html'); 
        res.send( fs.readFileSync('./index_admin.html') );
})

initIPAdress(); //Setup IP adress before app.listen()

app.listen(port, ipaddress, function() {
        console.log('%s: Node server started on %s:%d ...',
                        Date(Date.now() ), ipaddress, port);
});