3

私は次のように構造化されたnodejsサーバーを持っています:(app.js):

var fs = require('fs'),
    http = require('http'),
    https = require('https'),
    express = require('express'),
    connect = require('express/node_modules/connect'),
    app = module.exports = express();

var ssl_options = {
    key: fs.readFileSync('/etc/nginx/ssl/server.key'),
    cert: fs.readFileSync('/etc/nginx/ssl/server.crt')
};

var server = https.createServer(ssl_options, app);

// EXPRESS

// app.set('view options', { layout: false });

var auth_token = "asdfasfdasdfasdf";
var express_session_id = "express.sid";

app.configure(function () {
    app.use(express.cookieParser());
    app.use(express.session({secret: auth_token, key: express_session_id}));

    app.set("view options", {layout: false});
});

app.get('/', function (req, res) {
    console.log (req.headers);
    fs.readFile(__dirname + '/index.html', function(err, data){
        res.writeHead(200, {'Content-Type': 'text/html'});
        res.write(data, 'utf8');
        res.end();
    });
});

app.listen = function(port) {
    server.listen(port);
    console_log.log('info', "COTTONMOUTH server listening on port " + port);
};

上記の app.js を実行している cluster.js があります。

var cluster = require('cluster'),
    os = require('os'),
    workers = {};

if (cluster.isMaster) {

    cluster.on('exit', function(worker, code, signal) {
        if (worker.suicide === false) {
            var exitCode = worker.process.exitCode;
            console.error('worker ' + worker.process.pid + ' died ('+exitCode+'). restarting...');
            cluster.fork();
        }
    });

    var n = process.env.PROC || os.cpus().length;
    for(var i = 0; i < n; i++ ) {
        cluster.fork();
    }

    process.on('SIGTERM', function() {
        console.log('[MASTER] Going for shutdown...');
        for (var id in cluster.workers) { 
            console.log('\tkilling worker: ' + cluster.workers[id].process.pid);
            cluster.workers[id].destroy();
        }
        console.log("[MASTER] Here's looking at you, kid.");
    });

} else {
    require('./app').listen(process.env.PORT || 3456);
}

私の問題は、次のセットアップが私のlocalhost仮想ボックス環境(Macホストで実行されているubuntu仮想)で正常に機能することです。dev.domain.com:3456 で nodejs サーバーにアクセスできます。

ただし、これを実稼働ラックスペース サーバー (同じ環境構成とセットアップ) に移動し、prod.domain.com:3456 でアクセスしようとすると

ブラウザが少しハングして戻りますError 324 (net::ERR_EMPTY_RESPONSE): The server closed the connection without sending any data.

私はいくつかの調査を行い、いくつかのリードを見つけましたが、あまり役に立ちませんでした.

何か案は?

アップデート:

ポートを90に下げると、うまくいくようです。今のところポート 90 のままにしておきますが、誰かがこれがなぜなのか答えがあれば.

ありがとう

4

3 に答える 3