2022-11-04 09:52:27 +00:00
|
|
|
when (NimMajor, NimMinor) < (1, 4):
|
|
|
|
{.push raises: [Defect].}
|
|
|
|
else:
|
|
|
|
{.push raises: [].}
|
2022-10-18 11:37:44 +00:00
|
|
|
|
2022-09-30 12:43:42 +00:00
|
|
|
import
|
2022-10-18 11:37:44 +00:00
|
|
|
chronicles,
|
|
|
|
chronos,
|
2022-09-30 12:43:42 +00:00
|
|
|
metrics,
|
2022-10-18 11:37:44 +00:00
|
|
|
metrics/chronos_httpserver,
|
2022-11-21 14:15:03 +00:00
|
|
|
./constants,
|
2023-04-18 13:22:10 +00:00
|
|
|
../utils/collector
|
2022-09-30 12:43:42 +00:00
|
|
|
|
2024-03-15 23:08:47 +00:00
|
|
|
export metrics
|
2022-09-30 12:43:42 +00:00
|
|
|
|
2022-10-18 11:37:44 +00:00
|
|
|
logScope:
|
2022-11-03 15:36:24 +00:00
|
|
|
topics = "waku rln_relay"
|
2022-10-18 11:37:44 +00:00
|
|
|
|
2022-09-30 12:43:42 +00:00
|
|
|
func generateBucketsForHistogram*(length: int): seq[float64] =
|
|
|
|
## Generate a custom set of 5 buckets for a given length
|
|
|
|
let numberOfBuckets = 5
|
|
|
|
let stepSize = length / numberOfBuckets
|
|
|
|
var buckets: seq[float64]
|
2024-03-15 23:08:47 +00:00
|
|
|
for i in 1 .. numberOfBuckets:
|
2022-09-30 12:43:42 +00:00
|
|
|
buckets.add(stepSize * i.toFloat())
|
|
|
|
return buckets
|
|
|
|
|
2024-03-15 23:08:47 +00:00
|
|
|
declarePublicCounter(
|
|
|
|
waku_rln_messages_total, "number of messages published on the rln content topic"
|
|
|
|
)
|
2022-09-30 12:43:42 +00:00
|
|
|
declarePublicCounter(waku_rln_spam_messages_total, "number of spam messages detected")
|
2024-03-15 23:08:47 +00:00
|
|
|
declarePublicCounter(
|
|
|
|
waku_rln_invalid_messages_total, "number of invalid messages detected", ["type"]
|
|
|
|
)
|
2022-09-30 12:43:42 +00:00
|
|
|
# This metric will be useful in detecting the index of the root in the acceptable window of roots
|
2024-03-15 23:08:47 +00:00
|
|
|
declarePublicHistogram(
|
|
|
|
identifier = waku_rln_valid_messages_total,
|
2023-04-18 13:22:10 +00:00
|
|
|
help = "number of valid messages with their roots tracked",
|
2024-03-15 23:08:47 +00:00
|
|
|
buckets = generateBucketsForHistogram(AcceptableRootWindowSize),
|
|
|
|
)
|
|
|
|
declarePublicCounter(
|
|
|
|
waku_rln_errors_total,
|
|
|
|
"number of errors detected while operating the rln relay",
|
|
|
|
["type"],
|
|
|
|
)
|
|
|
|
declarePublicCounter(
|
|
|
|
waku_rln_proof_verification_total, "number of times the rln proofs are verified"
|
|
|
|
)
|
2023-09-11 13:51:45 +00:00
|
|
|
# this is a gauge so that we can set it based on the events we receive
|
2024-03-15 23:08:47 +00:00
|
|
|
declarePublicGauge(
|
|
|
|
waku_rln_number_registered_memberships,
|
|
|
|
"number of registered and active rln memberships",
|
|
|
|
)
|
2022-09-30 12:43:42 +00:00
|
|
|
|
|
|
|
# Timing metrics
|
2024-03-15 23:08:47 +00:00
|
|
|
declarePublicGauge(
|
|
|
|
waku_rln_proof_verification_duration_seconds, "time taken to verify a proof"
|
|
|
|
)
|
|
|
|
declarePublicGauge(
|
|
|
|
waku_rln_proof_generation_duration_seconds, "time taken to generate a proof"
|
|
|
|
)
|
|
|
|
declarePublicGauge(
|
|
|
|
waku_rln_instance_creation_duration_seconds, "time taken to create an rln instance"
|
|
|
|
)
|
|
|
|
declarePublicGauge(
|
|
|
|
waku_rln_membership_insertion_duration_seconds,
|
|
|
|
"time taken to insert a new member into the local merkle tree",
|
|
|
|
)
|
|
|
|
declarePublicGauge(
|
|
|
|
waku_rln_membership_credentials_import_duration_seconds,
|
|
|
|
"time taken to import membership credentials",
|
|
|
|
)
|
2022-10-18 11:37:44 +00:00
|
|
|
|
2024-03-15 23:08:47 +00:00
|
|
|
type RLNMetricsLogger = proc() {.gcsafe, raises: [Defect].}
|
2022-10-21 08:33:36 +00:00
|
|
|
|
|
|
|
proc getRlnMetricsLogger*(): RLNMetricsLogger =
|
|
|
|
var logMetrics: RLNMetricsLogger
|
2022-10-18 11:37:44 +00:00
|
|
|
|
|
|
|
var cumulativeErrors = 0.float64
|
|
|
|
var cumulativeMessages = 0.float64
|
|
|
|
var cumulativeSpamMessages = 0.float64
|
|
|
|
var cumulativeInvalidMessages = 0.float64
|
|
|
|
var cumulativeValidMessages = 0.float64
|
|
|
|
var cumulativeProofs = 0.float64
|
|
|
|
|
|
|
|
logMetrics = proc() =
|
|
|
|
{.gcsafe.}:
|
2024-03-15 23:08:47 +00:00
|
|
|
let freshErrorCount = parseAndAccumulate(waku_rln_errors_total, cumulativeErrors)
|
|
|
|
let freshMsgCount =
|
|
|
|
parseAndAccumulate(waku_rln_messages_total, cumulativeMessages)
|
|
|
|
let freshSpamCount =
|
|
|
|
parseAndAccumulate(waku_rln_spam_messages_total, cumulativeSpamMessages)
|
|
|
|
let freshInvalidMsgCount =
|
|
|
|
parseAndAccumulate(waku_rln_invalid_messages_total, cumulativeInvalidMessages)
|
|
|
|
let freshValidMsgCount =
|
|
|
|
parseAndAccumulate(waku_rln_valid_messages_total, cumulativeValidMessages)
|
|
|
|
let freshProofCount =
|
|
|
|
parseAndAccumulate(waku_rln_proof_verification_total, cumulativeProofs)
|
2023-04-18 13:22:10 +00:00
|
|
|
|
2022-10-18 11:37:44 +00:00
|
|
|
info "Total messages", count = freshMsgCount
|
|
|
|
info "Total spam messages", count = freshSpamCount
|
|
|
|
info "Total invalid messages", count = freshInvalidMsgCount
|
|
|
|
info "Total valid messages", count = freshValidMsgCount
|
|
|
|
info "Total errors", count = freshErrorCount
|
|
|
|
info "Total proofs verified", count = freshProofCount
|
|
|
|
return logMetrics
|