mirror of
https://github.com/waku-org/nwaku.git
synced 2025-01-28 07:35:56 +00:00
chore: waku_discv5, peer_manager - add more logs help debug discovery issues (#2705)
This commit is contained in:
parent
78132dc12e
commit
401630ee24
@ -199,8 +199,26 @@ proc searchLoop(wd: WakuDiscoveryV5) {.async.} =
|
|||||||
while wd.listening:
|
while wd.listening:
|
||||||
trace "running discv5 discovery loop"
|
trace "running discv5 discovery loop"
|
||||||
let discoveredRecords = await wd.findRandomPeers()
|
let discoveredRecords = await wd.findRandomPeers()
|
||||||
let discoveredPeers =
|
|
||||||
discoveredRecords.mapIt(it.toRemotePeerInfo()).filterIt(it.isOk()).mapIt(it.value)
|
var discoveredPeers: seq[RemotePeerInfo]
|
||||||
|
var wrongRecordsReasons: seq[tuple[record: string, errorDescription: string]]
|
||||||
|
## this is to store the reasons why certain records could not be converted to RemotePeerInfo
|
||||||
|
|
||||||
|
for record in discoveredRecords:
|
||||||
|
let peerInfo = record.toRemotePeerInfo().valueOr:
|
||||||
|
## in case of error, we keep track of it for debugging purposes
|
||||||
|
wrongRecordsReasons.add(($record, $error))
|
||||||
|
continue
|
||||||
|
|
||||||
|
discoveredPeers.add(peerInfo)
|
||||||
|
|
||||||
|
trace "discv5 discovered peers",
|
||||||
|
num_discovered_peers = discoveredPeers.len,
|
||||||
|
peers = toSeq(discoveredPeers.mapIt(shortLog(it.peerId)))
|
||||||
|
|
||||||
|
trace "discv5 discarded wrong records",
|
||||||
|
wrong_records =
|
||||||
|
wrongRecordsReasons.mapIt("(" & it.record & "," & it.errorDescription & ")")
|
||||||
|
|
||||||
for peer in discoveredPeers:
|
for peer in discoveredPeers:
|
||||||
# Peers added are filtered by the peer manager
|
# Peers added are filtered by the peer manager
|
||||||
|
@ -122,13 +122,14 @@ proc addPeer*(pm: PeerManager, remotePeerInfo: RemotePeerInfo, origin = UnknownO
|
|||||||
## Adds peer to manager for the specified protocol
|
## Adds peer to manager for the specified protocol
|
||||||
|
|
||||||
if remotePeerInfo.peerId == pm.switch.peerInfo.peerId:
|
if remotePeerInfo.peerId == pm.switch.peerInfo.peerId:
|
||||||
# Do not attempt to manage our unmanageable self
|
trace "skipping to manage our unmanageable self"
|
||||||
return
|
return
|
||||||
|
|
||||||
if pm.peerStore[AddressBook][remotePeerInfo.peerId] == remotePeerInfo.addrs and
|
if pm.peerStore[AddressBook][remotePeerInfo.peerId] == remotePeerInfo.addrs and
|
||||||
pm.peerStore[KeyBook][remotePeerInfo.peerId] == remotePeerInfo.publicKey and
|
pm.peerStore[KeyBook][remotePeerInfo.peerId] == remotePeerInfo.publicKey and
|
||||||
pm.peerStore[ENRBook][remotePeerInfo.peerId].raw.len > 0:
|
pm.peerStore[ENRBook][remotePeerInfo.peerId].raw.len > 0:
|
||||||
# Peer already managed and ENR info is already saved
|
trace "peer already managed and ENR info is already saved",
|
||||||
|
remote_peer_id = $remotePeerInfo.peerId
|
||||||
return
|
return
|
||||||
|
|
||||||
trace "Adding peer to manager",
|
trace "Adding peer to manager",
|
||||||
|
Loading…
x
Reference in New Issue
Block a user