From b64a622af4ca102b9936bab4558dfee28325be9a Mon Sep 17 00:00:00 2001 From: pm47 Date: Wed, 27 Sep 2023 18:15:33 +0200 Subject: [PATCH] add metrics on splicing This is best effort but should already be pretty useful. --- .../fr/acinq/eclair/channel/Monitoring.scala | 8 ++++++++ .../fr/acinq/eclair/channel/fsm/Channel.scala | 20 +++++++++++++++++++ 2 files changed, 28 insertions(+) diff --git a/eclair-core/src/main/scala/fr/acinq/eclair/channel/Monitoring.scala b/eclair-core/src/main/scala/fr/acinq/eclair/channel/Monitoring.scala index a6dbd9f2c9..e20d7ef3bb 100644 --- a/eclair-core/src/main/scala/fr/acinq/eclair/channel/Monitoring.scala +++ b/eclair-core/src/main/scala/fr/acinq/eclair/channel/Monitoring.scala @@ -31,6 +31,7 @@ object Monitoring { val HtlcValueInFlightGlobal = Kamon.gauge("channels.htlc-value-in-flight-global", "Global HTLC value in flight across all channels") val LocalFeeratePerByte = Kamon.histogram("channels.local-feerate-per-byte") val RemoteFeeratePerByte = Kamon.histogram("channels.remote-feerate-per-byte") + val Splices = Kamon.histogram("channels.splices", "Splices") val ProcessMessage = Kamon.timer("channels.messages-processed") def recordHtlcsInFlight(remoteSpec: CommitmentSpec, previousRemoteSpec: CommitmentSpec): Unit = { @@ -56,6 +57,7 @@ object Monitoring { val Origin = "origin" val State = "state" val CommitmentFormat = "commitment-format" + val SpliceType = "splice-type" object Events { val Created = "created" @@ -72,6 +74,12 @@ object Monitoring { val Incoming = "incoming" val Outgoing = "outgoing" } + + object SpliceTypes { + val SpliceIn = "splice-in" + val SpliceOut = "splice-out" + val SpliceCpfp = "splice-cpfp" + } } } diff --git a/eclair-core/src/main/scala/fr/acinq/eclair/channel/fsm/Channel.scala b/eclair-core/src/main/scala/fr/acinq/eclair/channel/fsm/Channel.scala index fa34d2f806..e941e62d57 100644 --- a/eclair-core/src/main/scala/fr/acinq/eclair/channel/fsm/Channel.scala +++ b/eclair-core/src/main/scala/fr/acinq/eclair/channel/fsm/Channel.scala @@ -1091,6 +1091,26 @@ class Channel(val nodeParams: NodeParams, val wallet: OnChainChannelFunder with val commitments1 = d.commitments.add(signingSession1.commitment) val d1 = d.copy(commitments = commitments1, spliceStatus = SpliceStatus.NoSplice) log.info("publishing funding tx for channelId={} fundingTxId={}", d.channelId, signingSession1.fundingTx.sharedTx.txId) + val fundingParams = signingSession1.fundingTx.fundingParams + val sharedTx = signingSession1.fundingTx.sharedTx.tx + if (fundingParams.localContribution > 0.sat) { + Metrics.Splices.withTag(Tags.Origin, Tags.Origins.Local).withTag(Tags.SpliceType, Tags.SpliceTypes.SpliceIn).record(fundingParams.localContribution.toLong) + } + if (fundingParams.remoteContribution > 0.sat) { + Metrics.Splices.withTag(Tags.Origin, Tags.Origins.Remote).withTag(Tags.SpliceType, Tags.SpliceTypes.SpliceIn).record(fundingParams.remoteContribution.toLong) + } + if (sharedTx.localOutputs.nonEmpty) { + Metrics.Splices.withTag(Tags.Origin, Tags.Origins.Local).withTag(Tags.SpliceType, Tags.SpliceTypes.SpliceOut).record(sharedTx.localOutputs.map(_.amount).sum.toLong) + } + if (sharedTx.remoteOutputs.nonEmpty) { + Metrics.Splices.withTag(Tags.Origin, Tags.Origins.Remote).withTag(Tags.SpliceType, Tags.SpliceTypes.SpliceOut).record(sharedTx.remoteOutputs.map(_.amount).sum.toLong) + } + if (fundingParams.localContribution < 0.sat && sharedTx.localOutputs.isEmpty) { + Metrics.Splices.withTag(Tags.Origin, Tags.Origins.Local).withTag(Tags.SpliceType, Tags.SpliceTypes.SpliceCpfp).record(fundingParams.localContribution.toLong) + } + if (fundingParams.remoteContribution < 0.sat && sharedTx.remoteOutputs.isEmpty) { + Metrics.Splices.withTag(Tags.Origin, Tags.Origins.Remote).withTag(Tags.SpliceType, Tags.SpliceTypes.SpliceCpfp).record(fundingParams.remoteContribution.toLong) + } stay() using d1 storing() sending signingSession1.localSigs calling publishFundingTx(signingSession1.fundingTx) calling endQuiescence(d1) } case _ =>