私は次のように構造化された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 のままにしておきますが、誰かがこれがなぜなのか答えがあれば.
ありがとう