deploy: ed53bcdec6c8e1eecd5da9991ebc37def00cb090

This commit is contained in:
rymnc 2022-08-31 10:28:11 +00:00
parent 1cfb1720b4
commit 24ef6196c5
3 changed files with 37 additions and 12 deletions

View File

@ -2,7 +2,7 @@
# libtool - Provide generalized library-building support services. # libtool - Provide generalized library-building support services.
# Generated automatically by config.status (libbacktrace) version-unused # Generated automatically by config.status (libbacktrace) version-unused
# Libtool was configured on host fv-az105-780: # Libtool was configured on host fv-az198-353:
# NOTE: Changes made to this file will be lost: look at ltmain.sh. # NOTE: Changes made to this file will be lost: look at ltmain.sh.
# #
# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2003, 2004, 2005, # Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2003, 2004, 2005,

View File

@ -324,7 +324,7 @@ type
metricsLogging* {. metricsLogging* {.
desc: "Enable metrics logging: true|false" desc: "Enable metrics logging: true|false"
defaultValue: false defaultValue: true
name: "metrics-logging" }: bool name: "metrics-logging" }: bool
## DNS discovery config ## DNS discovery config

View File

@ -8,7 +8,10 @@ import
metrics, metrics,
metrics/chronos_httpserver, metrics/chronos_httpserver,
./config, ./config,
./wakunode2 ./wakunode2,
../protocol/waku_filter,
../protocol/waku_store,
../protocol/waku_lightpush
logScope: logScope:
topics = "wakunode.setup.metrics" topics = "wakunode.setup.metrics"
@ -24,24 +27,46 @@ proc startMetricsServer*(serverIp: ValidIpAddress, serverPort: Port) =
info "Metrics HTTP server started", serverIp, serverPort info "Metrics HTTP server started", serverIp, serverPort
proc parseCollectorIntoF64(collector: Collector): float64 =
var total = 0.float64
for key in collector.metrics.keys():
try:
total = total + collector.value(key)
except KeyError:
discard
return total
proc startMetricsLog*() = proc startMetricsLog*() =
# https://github.com/nim-lang/Nim/issues/17369 # https://github.com/nim-lang/Nim/issues/17369
var logMetrics: proc(udata: pointer) {.gcsafe, raises: [Defect].} var logMetrics: proc(udata: pointer) {.gcsafe, raises: [Defect].}
var cumulativeErrors = 0.float64
var cumulativeConns = 0.float64
logMetrics = proc(udata: pointer) = logMetrics = proc(udata: pointer) =
{.gcsafe.}: {.gcsafe.}:
# TODO: libp2p_pubsub_peers is not public, so we need to make this either # 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. # public in libp2p or do our own peer counting after all.
var totalMessages = 0.float64
for key in waku_node_messages.metrics.keys():
try:
totalMessages = totalMessages + waku_node_messages.value(key)
except KeyError:
discard
info "Node metrics", totalMessages let totalErrors = parseCollectorIntoF64(waku_node_errors)
discard setTimer(Moment.fromNow(2.seconds), logMetrics) let totalConnections = parseCollectorIntoF64(waku_node_conns_initiated)
discard setTimer(Moment.fromNow(2.seconds), logMetrics) # track cumulative, and then max.
let freshErrorCount = max(totalErrors - cumulativeErrors, 0)
let freshConnCount = max(totalConnections - cumulativeConns, 0)
cumulativeErrors = totalErrors
cumulativeConns = totalConnections
info "Total connections initiated", count = freshConnCount
info "Total messages", count = parseCollectorIntoF64(waku_node_messages)
info "Total swap peers", count = parseCollectorIntoF64(waku_swap_peers_count)
info "Total filter peers", count = parseCollectorIntoF64(waku_filter_peers)
info "Total store peers", count = parseCollectorIntoF64(waku_store_peers)
info "Total lightpush peers", count = parseCollectorIntoF64(waku_lightpush_peers)
info "Total errors", count = freshErrorCount
info "Total active filter subscriptions", count = parseCollectorIntoF64(waku_filter_subscribers)
discard setTimer(Moment.fromNow(30.seconds), logMetrics)
discard setTimer(Moment.fromNow(30.seconds), logMetrics)