我面临以下挑战。我尝试通过 websocket 订阅“newPendingTransactions”。我可以成功连接到 websocket。连接后,我希望有新的传入待处理事务流,我可以读出这些事务并将其传播到某个通道 (chan json.RawMessage)。...c, httpResponse, err := websocket.DefaultDialer.Dial(u.String(), req.Header)...for { messageType, message, err := c.ReadMessage() if err != nil { log.Println("ERROR:", err) os.Exit(1) return } _, _ = message, messageType // s.Out is the outgoing chan json.RawMessage s.Out <- message}...遗憾的是我没有收到任何消息(待处理的 tx).. 只有一条关于关闭整个结构的消息。当我在控制台中直接使用“txpool.status”检查我的节点时,我可以看到一直有新的待处理 tx 传入。他们只是不想传播到我的 websocket 连接。有人可以帮我吗?也许我缺少启动 geth 节点本身的参数?这是我启动 geth 节点的方式:geth --http.api eth,web3,debug,txpool,net,shh,db,admin,debug --http --ws --ws.api eth,web3,debug,txpool,net,shh,db,admin,debug --ws.origins localhost --gcmode full --http.port=8545 --maxpeers 120这是我的“admin.nodeInfo”:Geth/v1.10.16-stable-20356e57/linux-amd64/go1.17.5
1 回答
慕村225694
TA贡献1880条经验 获得超4个赞
我发现我做错了什么:
这与任何被遗忘的 geth 参数无关,甚至与正确传播“newPendingTransactions”无关。
我使用另一个名为“wscat”的工具测试了 websocket 连接,并通过控制台发送了必要的 rpc(产生了 tx 哈希流!)
{"id": 1, "method": "eth_subscribe", "params": ["newPendingTransactions"]}
它告诉我错误一定是关于 golang 代码本身的。
for 循环中的最后一行
s.Out <- message
正在将消息发送到无缓冲通道。为了使其工作,其他一些 go 例程必须使用另一端的通道消息。
它还有助于使用这样的缓冲通道:
s.Out = make(chan Message, 1000)
...所以至少会发送 1000 条消息
- 1 回答
- 0 关注
- 98 浏览
添加回答
举报
0/150
提交
取消