nwaku/waku/v2/node/waku_metrics.nim
Aaryamann Challani bdb120d842
feat(chat2): metrics server + metrics logging (#1279)
* feat(rln-relay): periodically log metrics

* fix(chat2): enable metrics by default in chat2 config

* test(chat2): metrics, gc compilation error

* chore(metrics): make metrics a util, and import into wakunode2 apps dir

* fix(metrics): raise error

* fix(metrics): gc error

* fix(wakunode2): remove setup_metrics

* chore(metrics): waku utils metrics

* fix(metrics): create waku_metrics in node dir

* fix(metrics): log scope

* fix(chat2): disable metrics server by default

* fix(utils): collectorAsF64 proc def

* fix(metrics): store metrics path
2022-10-21 14:03:36 +05:30

78 lines
2.5 KiB
Nim

{.push raises: [Defect].}
import
stew/results,
stew/shims/net,
chronicles,
chronos,
metrics,
metrics/chronos_httpserver
import
../protocol/waku_filter,
../protocol/waku_store/protocol_metrics,
../protocol/waku_lightpush,
../protocol/waku_swap/waku_swap,
../protocol/waku_peer_exchange,
../utils/collector,
./peer_manager/peer_manager,
./waku_node
when defined(rln) or defined(rlnzerokit):
import ../protocol/waku_rln_relay/waku_rln_relay_metrics
const LogInterval = 30.seconds
logScope:
topics = "waku.metrics"
proc startMetricsServer*(serverIp: ValidIpAddress, serverPort: Port) =
info "Starting metrics HTTP server", serverIp, serverPort
try:
startMetricsHttpServer($serverIp, serverPort)
except Exception as e:
raiseAssert("Exception while starting metrics HTTP server: " & e.msg)
info "Metrics HTTP server started", serverIp, serverPort
type
# https://github.com/nim-lang/Nim/issues/17369
MetricsLogger = proc(udata: pointer) {.gcsafe, raises: [Defect].}
proc startMetricsLog*() =
var logMetrics: MetricsLogger
var cumulativeErrors = 0.float64
var cumulativeConns = 0.float64
when defined(rln) or defined(rlnzerokit):
let logRlnMetrics = getRlnMetricsLogger()
logMetrics = proc(udata: pointer) =
{.gcsafe.}:
# TODO: libp2p_pubsub_peers is not public, so we need to make this either
# public in libp2p or do our own peer counting after all.
# track cumulative values
let freshErrorCount = parseAndAccumulate(waku_node_errors, cumulativeErrors)
let freshConnCount = parseAndAccumulate(waku_node_conns_initiated, cumulativeConns)
info "Total connections initiated", count = freshConnCount
info "Total messages", count = collectorAsF64(waku_node_messages)
info "Total swap peers", count = collectorAsF64(waku_swap_peers_count)
info "Total filter peers", count = collectorAsF64(waku_filter_peers)
info "Total store peers", count = collectorAsF64(waku_store_peers)
info "Total lightpush peers", count = collectorAsF64(waku_lightpush_peers)
info "Total peer exchange peers", count = collectorAsF64(waku_px_peers)
info "Total errors", count = freshErrorCount
info "Total active filter subscriptions", count = collectorAsF64(waku_filter_subscribers)
# Start protocol specific metrics logging
when defined(rln) or defined(rlnzerokit):
logRlnMetrics()
discard setTimer(Moment.fromNow(LogInterval), logMetrics)
discard setTimer(Moment.fromNow(LogInterval), logMetrics)