V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
zhfsxtx
V2EX  ›  问与答

今天晚上V2EX好像挂了一会,我的公众号给挂了

  •  
  •   zhfsxtx · 2013-03-26 23:52:03 +08:00 · 2595 次点击
    这是一个创建于 4293 天前的主题,其中的信息可能已经有所发展或是发生改变。
    看LOG是解析返回的JSON有问题。
    var topics = JSON.parse(buf.toString());
    SyntaxError: Unexpected end of input
    at Object.parse (native)
    at IncomingMessage.<anonymous> (/root/node/3w/weixin/v2ex/routes/handler.js:24:23)
    at IncomingMessage.EventEmitter.emit (events.js:92:17)
    at emitReadable_ (_stream_readable.js:382:10)
    at emitReadable (_stream_readable.js:377:5)
    at onEofChunk (_stream_readable.js:357:5)
    at readableAddChunk (_stream_readable.js:129:5)
    at IncomingMessage.Readable.push (_stream_readable.js:112:10)
    at Socket.socketCloseListener (http.js:1462:9)
    at Socket.EventEmitter.emit (events.js:117:20)
    at TCP.close (net.js:436:12)

    因为一个JSON错导致整个APP挂不应该啊,在NODEJS 里面是怎么做容错的啊。
    4 条回复    1970-01-01 08:00:00 +08:00
    Livid
        1
    Livid  
    MOD
       2013-03-26 23:53:25 +08:00
    今天我们因为受到攻击,确实不太稳定。

    你的程序中,应该检测从 V2EX 返回的 API Response 的 http status code,如果不是 200,那么肯定有问题。
    zhfsxtx
        2
    zhfsxtx  
    OP
       2013-03-26 23:57:30 +08:00
    @Livid 知道了
    zhfsxtx
        3
    zhfsxtx  
    OP
       2013-03-27 00:01:35 +08:00
    @Livid 刚回头看了下代码,里面已经有加检测http status code的代码了,但还 是挂了。

    if (response .statusCode != 200) {
    console.log("unnormal statusCode: " + response .statusCode);
    return;
    };
    zhfsxtx
        4
    zhfsxtx  
    OP
       2013-03-27 00:04:06 +08:00
    20 response .on('readable', function () {
    21 var buf = response .read(1024*1024);
    22 if(buf === null) return;
    23
    24 var topics = JSON.parse(buf.toString());
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5882 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 29ms · UTC 02:18 · PVG 10:18 · LAX 18:18 · JFK 21:18
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.