Python / Node ZeroRPC心跳错误

时间:2014-05-18 14:03:10

标签: python node.js zeromq zerorpc

我试图从ZeroRPC website运行Python server / node.js客户端HelloWorld示例。所有重要的库似乎都已正确安装,但在运行示例时我收到错误:

{ name: 'HeartbeatError',
  message: 'Lost remote after 10000ms',
  traceback: '' }

有没有人见过这个?

2 个答案:

答案 0 :(得分:2)

我正在使用" zerorpc":" ^ 0.9.3" 当我运行一个耗时的python代码时,我遇到了同样的问题。解决问题的方法是你需要修改zerorpc的库代码: node_modules - > zerorpc - > lib - > channel.js 将cooresponding方法更改为

//Runs the heartbeat on this channel
Channel.prototype._runHeartbeat = function() {
    var self = this;

    return setInterval(function() {
        if(util.curTime() > self._heartbeatExpirationTime) {
            //If we haven't received a response in 2 * heartbeat rate, send an
            //error
//            self.emit("heartbeat-error", "Lost remote after " + (HEARTBEAT * 2) + "ms");
//            self.close();
        }

        //Heartbeat on the channel
        try {
            var event = events.create(self._envelope, self._createHeader(), "_zpc_hb", [0]);
            self._socket.send(event);
        } catch(e) {
            console.error("Error occurred while sending heartbeat:", e);
        }
    }, HEARTBEAT);
};

来自github的最新代码:https://github.com/dotcloud/zerorpc-node 他们已经解决了这个问题。

答案 1 :(得分:0)

如果可以,请使用gevent.sleep让zerorpc有足够的时间来处理等待的消息,包括心跳。