node.js - nodejs + https + express - 错误 324 (net::ERR_EMPTY_RESPONSE)

标签 node.js nginx express

我有一个结构如下的 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 virtual box 环境(在 mac 主机上运行的 ubuntu 虚拟机)上运行良好。我可以使用 dev.domain.com:3456 访问 nodejs 服务器。

但是,当我将它移动到我的生产机架空间服务器(相同的环境配置和设置),并尝试通过 prod.domain.com:3456 访问它时

浏览器挂起并返回 错误 324 (net::ERR_EMPTY_RESPONSE):服务器关闭连接但未发送任何数据。

我做了一些研究并找到了一些线索,但帮助不大。

有什么想法吗?

更新:

当我将端口降低到 90 时,它似乎起作用了,这很有趣。 我暂时将它留在端口 90,但如果有人知道这是为什么。

谢谢

最佳答案

当我的请求变得太大 (>65K) 时,我收到了这条错误消息。我的解决方案是将数据缩减为几个片段。

关于node.js - nodejs + https + express - 错误 324 (net::ERR_EMPTY_RESPONSE),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15917079/

相关文章:

javascript - turf.js 可以用来查找和修复错误的 geojson 几何图形吗?

nginx - 如何配置 nginx 与 Jetty6 网络服务器一起工作?

php - Nginx 虚拟主机不工作

Node.js/Express - 通过请求/响应对象修改响应模板上下文

node.js - 嵌入式 JavaScript (EJS) - 从路线动态设置 View

node.js - 为什么restify没有自己的插件来支持cookie?

linux - 如何停止nginx?它不断杀死一个进程并打开一个具有不同 pid 的新进程

node.js - 构建处理 MongoDB 查询的 Express 路由的最佳实践

node.js - 处理 JWT 验证失败

node.js - 如何使用 npm 安装 PhantomJS v2