2024-08-21 12:54:18 +00:00
|
|
|
when (NimMajor, NimMinor) < (1, 4):
|
|
|
|
{.push raises: [Defect].}
|
|
|
|
else:
|
|
|
|
{.push raises: [].}
|
|
|
|
|
|
|
|
import
|
|
|
|
std/[options, strutils, os, sequtils, net, strformat],
|
|
|
|
chronicles,
|
|
|
|
chronos,
|
|
|
|
metrics,
|
|
|
|
libbacktrace,
|
|
|
|
system/ansi_c,
|
|
|
|
libp2p/crypto/crypto,
|
|
|
|
confutils,
|
|
|
|
libp2p/wire
|
|
|
|
|
|
|
|
import
|
|
|
|
../../waku/common/logging,
|
|
|
|
../../waku/factory/waku,
|
|
|
|
../../waku/factory/external_config,
|
|
|
|
../../waku/node/health_monitor,
|
|
|
|
../../waku/node/waku_metrics,
|
|
|
|
../../waku/waku_api/rest/builder as rest_server_builder,
|
|
|
|
../../waku/node/peer_manager,
|
|
|
|
../../waku/waku_lightpush/common,
|
|
|
|
../../waku/waku_relay,
|
|
|
|
../../waku/waku_filter_v2,
|
|
|
|
../../waku/waku_api/rest/client,
|
|
|
|
../../waku/waku_api/rest/admin/client,
|
|
|
|
./tester_config,
|
|
|
|
./lightpush_publisher,
|
|
|
|
./filter_subscriber
|
|
|
|
|
|
|
|
logScope:
|
|
|
|
topics = "diagnose connections"
|
|
|
|
|
|
|
|
proc logSelfPeersLoop(pm: PeerManager, interval: Duration) {.async.} =
|
|
|
|
trace "Starting logSelfPeersLoop diagnosis loop"
|
|
|
|
while true:
|
2024-09-27 12:46:46 +00:00
|
|
|
let selfLighpushPeers = pm.wakuPeerStore.getPeersByProtocol(WakuLightPushCodec)
|
|
|
|
let selfRelayPeers = pm.wakuPeerStore.getPeersByProtocol(WakuRelayCodec)
|
|
|
|
let selfFilterPeers = pm.wakuPeerStore.getPeersByProtocol(WakuFilterSubscribeCodec)
|
2024-08-21 12:54:18 +00:00
|
|
|
|
|
|
|
let printable = catch:
|
|
|
|
"""*------------------------------------------------------------------------------------------*
|
|
|
|
| Self ({pm.switch.peerInfo}) peers:
|
|
|
|
*------------------------------------------------------------------------------------------*
|
|
|
|
| Lightpush peers({selfLighpushPeers.len()}): ${selfLighpushPeers}
|
|
|
|
*------------------------------------------------------------------------------------------*
|
|
|
|
| Filter peers({selfFilterPeers.len()}): ${selfFilterPeers}
|
|
|
|
*------------------------------------------------------------------------------------------*
|
|
|
|
| Relay peers({selfRelayPeers.len()}): ${selfRelayPeers}
|
|
|
|
*------------------------------------------------------------------------------------------*""".fmt()
|
|
|
|
|
|
|
|
if printable.isErr():
|
|
|
|
echo "Error while printing statistics: " & printable.error().msg
|
|
|
|
else:
|
|
|
|
echo printable.get()
|
|
|
|
|
|
|
|
await sleepAsync(interval)
|
|
|
|
|
|
|
|
proc logServiceRelayPeers(
|
|
|
|
pm: PeerManager, codec: string, interval: Duration
|
|
|
|
) {.async.} =
|
|
|
|
trace "Starting service node connectivity diagnosys loop"
|
|
|
|
while true:
|
|
|
|
echo "*------------------------------------------------------------------------------------------*"
|
|
|
|
echo "| Service peer connectivity:"
|
|
|
|
let selfLighpushPeers = pm.selectPeer(codec)
|
|
|
|
if selfLighpushPeers.isSome():
|
|
|
|
let ma = selfLighpushPeers.get().addrs[0]
|
|
|
|
var serviceIp = initTAddress(ma).valueOr:
|
|
|
|
echo "Error while parsing multiaddress: " & $error
|
|
|
|
continue
|
|
|
|
|
|
|
|
serviceIp.port = Port(8645)
|
|
|
|
let restClient = newRestHttpClient(initTAddress($serviceIp))
|
|
|
|
|
|
|
|
let getPeersRes = await restClient.getPeers()
|
|
|
|
|
|
|
|
if getPeersRes.status == 200:
|
|
|
|
let nrOfPeers = getPeersRes.data.len()
|
|
|
|
echo "Service node (@" & $ma & ") peers: " & $getPeersRes.data
|
|
|
|
else:
|
|
|
|
echo "Error while fetching service node (@" & $ma & ") peers: " &
|
|
|
|
$getPeersRes.data
|
|
|
|
else:
|
|
|
|
echo "No service node peers found"
|
|
|
|
|
|
|
|
echo "*------------------------------------------------------------------------------------------*"
|
|
|
|
|
|
|
|
await sleepAsync(interval)
|
|
|
|
|
|
|
|
proc startPeriodicPeerDiagnostic*(pm: PeerManager, codec: string) {.async.} =
|
|
|
|
asyncSpawn logSelfPeersLoop(pm, chronos.seconds(60))
|
|
|
|
# asyncSpawn logServiceRelayPeers(pm, codec, chronos.seconds(20))
|