为什么我的 "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 条消息