目前我们有两种不同的 API。您正在使用的我们称为“v0”API。它针对长轮询 Javascript 客户端进行了优化。我的猜测是,您的订阅会在某个硬编码超时(恰好是 10 秒)之前获得收益。您是否尝试过在eventPoll
通话后快速接听eventSubscribe
电话?
这是“v0”收割功能:https ://github.com/eris-ltd/eris-db/blob/master/event/event_cache.go#L72 。它循环运行,清除最近未轮询的旧订阅。如果您在轮询前等待超过 10 秒,那么您的订阅可能已被收割(删除)。
我们还有另一个针对链管理优化的 API,称为“tendermint”API(因为它继承自 Tendermint 共识引擎)。它是一种并行 API,由 eris-pm 工具使用。它还有一个可通过 websocket 端点访问的订阅方法。这可能对您有用,因为它的订阅永远不会被收割。
你可以这样尝试:
启动你的链:
$ eris chains start testchain
获取一个简单的 websocket 客户端:
$ go get github.com/raphael/wsc
连接到 websocket 端点:
$ wsc ws://0.0.0.0:46657/websocket
2017/01/21 01:03:51 connecting to ws://0.0.0.0:46657/websocket...
2017/01/21 01:03:51 ready, exit with CTRL+C.
NewBlock
通过粘贴{ "jsonrpc": "2.0", "method": "subscribe", "params": ["NewBlock"] }
到终端作为单行订阅事件:
>> { "jsonrpc": "2.0", "method": "subscribe", "params": ["NewBlock"] }
然后你应该会收到一个新的块事件流(大约每秒 1 个),例如:
<< {"jsonrpc":"2.0","id":"#event","result":[19 {"event":"NewBlock","data":[1,{"block":{"header":{"chain_id":"testchain","height":206320,"time":"2017-01-21T01:04:01.095Z","num_txs":0,"last_block_hash":"2DB0D0AE6D92DA6DA07F8E7D1605AAB6CB96D8D2","last_block_parts":{"total":1,"hash":"A4AD1708714CF0BE3E5125B65F495DDDFA1ED8D9"},"last_commit_hash":"4C301C0367B7CECDD4E00C955D2F155802B2377E","data_hash":"","validators_hash":"46E43215C6C332446114BF7320D2D007114C5EEB","app_hash":"9A72DE9AAD6BD820A64DB98462CD706594217E1
<< 1"},"data":{"txs":[]},"last_commit":{"precommits":[{"height":206319,"round":0,"type":2,"block_hash":"2DB0D0AE6D92DA6DA07F8E7D1605AAB6CB96D8D2","block_parts_header":{"total":1,"hash":"A4AD1708714CF0BE3E5125B65F495DDDFA1ED8D9"},"signature":"45A6C3D0B0BD380A239F014681A29FD6217B52653CC7FC189FF5B7DC840A61062CF12FC652687A30A5CBBF0270937F32542D6075BA94A12180568560B322EC07"}]}}}]}],"error":""}
您可以使用您选择的编程 websocket 客户端与使用此 websocket API 的链进行交互,并且您的订阅将永远不会被收割。
这些 API 很快就会进行大规模统一,这将使它们更易于使用和更好地记录。
如果您需要帮助调试,请加入我们:https ://monax.slack.com/