内存泄漏问题Nodejs(无法使用v8profiler进行调试)

4
我在一款当前正在生产环境中使用的nodeJS应用程序(一个S3多部分上传服务器的代理)中遇到了一些内存问题,因此我正在尝试寻找一种检测和预防的方法。我发现了这个教程,但是当我打开调试页面时,配置选项卡没有显示(我已经按照教程的步骤进行了操作)。我做错了什么吗? (我正在按照这个教程进行操作:https://github.com/felixge/node-memory-leak-tutorial
如果有帮助的话,这是可能导致泄漏的代码的一部分:
IngestionClient.prototype.multipartUpload = function(params, req, res, aReqLength) {
var self = this;
var client = this.client[params.profile];
var dest = params.file;

logger.debug('PART ' + params.query.partNumber + '/' + params.query.totalSize +': BEGIN : '+req.headers['content-length']+' bytes : ['
        + params.file_id + ']');

var amazonRequest = client.request('PUT', '/' + dest
        + '?partNumber=' + params.query.partNumber + '&uploadId='
        + params.query.uploadId, {
    'Content-Length' : req.headers['content-length']
});

var partLength = 0;

req.on('data', function(data) {
    partLength += data.length;
    amazonRequest.write(data, 'binary');
});

req.on('end', function() {
    if(partLength == req.headers['content-length']) {
        logger.debug('PART ' + params.query.partNumber + '/' + params.query.totalSize +': CLIENT_RECEIVED_COMPLETE : ['
                + params.file_id + ']');
    }else {
        logger.error('PART ' + params.query.partNumber + '/' + params.query.totalSize +': CLIENT_RECEIVED_INCOMPLETE : Esperado '+req.headers['content-length']
        +' bytes / Recebido ' + partLength + ' : [' + params.file_id + ']');
        amazonRequest.abort();
        self.sendError(params, res);
    }

});

amazonRequest.on('response', function(amazonResponse) {
    var responseText;

        if (amazonResponse.statusCode == 200 && amazonResponse.headers.etag.length > 0) {
            self.queryDB(
                    'INSERT INTO SAMBAFILES_UPLOAD_CONTROL_PARTS SET FILE_ID="'
                            + params.file_id + '", ETAG=' + amazonResponse.headers.etag
                            + ', PART_NUMBER="' + params.query.partNumber + '"',
                    function(err, results) {
                        logger.debug('PART ' + params.query.partNumber + '/' + params.query.totalSize +': S3_PUT_COMPLETE : ['
                                + params.file_id + ']');            
                        responseText = '{"success": true}';
                        res.end(responseText);
                        self.checkComplete(params, dest);
                    });
        } else {
            var responseBody = "";
            amazonResponse.on('data', function(dataRes) {
                responseBody += dataRes;
            });

            amazonResponse.on("end", function(){
                if(responseBody.indexOf("<Code>RequestTimeout</Code>") > 0) {
                    //Erro de lentidao do envio ( + de 20 segundos ). Browser fará um retry
                    logger.error('PART ' + params.query.partNumber + '/' + params.query.totalSize +': S3_PUT_ERROR_TIMEOUT : Response Code ' 
                            + amazonResponse.statusCode + ' : [' + params.file_id + ']');
                }else {
                    logger.error('PART ' + params.query.partNumber + '/' + params.query.totalSize +': S3_PUT_ERROR : Response Code ' 
                            + amazonResponse.statusCode + ': ' + responseBody + ' : [' + params.file_id + ']');
                }
                amazonRequest.abort();
                self.sendError(params, res);

            });

        }

        console.log(util.inspect(process.memoryUsage()));

}).end();

};

基本上,我从浏览器接收到的每个部分都会使用接收到的参数和请求向亚马逊发出请求。 Node 版本为 0.6.7。

谢谢!


我建议你也尝试使用最新的0.8.x版本的Node.js。 - Alfred
我会在弄清楚发生了什么之后再做。只是更新我的节点会给问题增加另一个变量,所以我希望先检测一下。 - Thiago Miranda de Oliveira
问题可能是 node.js 本身存在内存泄漏。这就是为什么我要求您更新 node.js 的原因。 - Alfred
HTTP客户端在0.6.17中修复了一个内存泄漏问题。您可能还想为请求和响应对象添加“close”处理程序。此外,我使用node-webkit-agent非常成功。 - rrjamie
3个回答

2

1

0
以下插件已更新以适配新版本的v8。除了nodetime.com之外,这是唯一仍在运作的插件。它使用实际的webkit调试器:

https://github.com/c4milo/node-webkit-agent

它有非常清晰的指示。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接