为什么我的 "newPendingTransactions" geth 订阅没有收到任何事件?
why does my "newPendingTransactions" geth subscription not get any events?
我面临以下挑战。我尝试通过 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
我发现我做错了什么:
这与任何遗忘的 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 条消息
我面临以下挑战。我尝试通过 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
我发现我做错了什么:
这与任何遗忘的 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 条消息