0

データをリモート API に投稿し、応答を取得するノード アプリがあります。正常に動作しますが、ノード サーバーがクラッシュし、次のエラーが生成されることがあります。

 events.js:71
throw arguments[1]; // Unhandled 'error' event
^
Error: socket hang up
at createHangUpError (http.js:1264:15)
at Socket.socketCloseListener (http.js:1315:23)
at Socket.EventEmitter.emit (events.js:126:20)
at Socket._destroy.destroyed (net.js:358:10)
at process.startup.processNextTick.process._tickCallback (node.js:244:9)

グーグルで調べたところ、タイムアウトが原因で発生することがわかりましたが、これを克服する方法についてはよくわかりません。私のserver.jsに必要なコードは次のとおりです。

if(request.body.company=="CQ")
    {
        var postData={firstName:request.body.firstname,lastName:request.body.lastname,Email:request.body.email,DayPhoneNumber:request.body.daytimePhone,Address1:request.body.addressOne,city:request.body.city,state:request.body.State,postalCode:request.body.zip,AreaOfIntrest:request.body.areaOfInterest,VendorLocationId:"38404",Notes:request.body.Notes,GraduationYear:request.body.graduationYear,AffiliateLocationId:"12345",LocationId:"12345",CampaignId:"12345"};

        var options={hostname:'webservices.someapi.com', path:'/ILM/Default.ashx?'+qs.stringify(postData), method:'GET'};

        var req = http.request(options, function(res) {

        res.on('data', function (chunk) {

        edModel.find({$and:[{daytimePhone:request.body.daytimePhone},{company:"CQ"}]},function(err,count){
        if(count.length==0)
        {
                var sr='RESPONSE: ' + chunk;
                if(sr.indexOf('status="Error"')==-1)
                {
                    request.body.leadid=sr;
                    var sr=sr.slice(sr.indexOf("leadid"));
                    sr=sr.slice(0,sr.indexOf(">"));

                    edDoc=new edModel(request.body);
                    edDoc.save();       
                    response.send({response:sr});
                }
                else
                {
                    response.send({response:sr});
                }
        }
        else
        {
            response.send({response:"<span style='color:red'>Duplicate Lead.<br> A lead with this number already exists in our database</span>"});
        }

    });


        });

        });

        // write data to request body
        req.write('data\n');
        req.end();
    }

server.js ファイルに if else 条件がいくつかあります。

4

1 に答える 1

0

ノード 0.8.20 では、その問題に関するバグがありました。http.request の代わりに http.get を使用してみてください。または、そのバージョンを使用する場合は 0.8.20 を使用しないでください。

于 2013-06-18T10:06:31.400 に答える