Skip to content

Commit

Permalink
Merge pull request #200 from austinwarrren/finagle-metrics
Browse files Browse the repository at this point in the history
Adds StatsReceiver to ThriftClientConfiguration
  • Loading branch information
bpholt authored Oct 23, 2024
2 parents 07c5cf6 + f5046c1 commit aa5c3bc
Show file tree
Hide file tree
Showing 2 changed files with 12 additions and 6 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,7 @@ object ThriftClient {
.withTransport.connectTimeout(config.transportConnectTimeout)
.withRetryBudget(config.retryBudget)
.withTracer(config.tracer)
.withStatsReceiver(config.statsReceiver)
.build[MPE.MPE](dest)(MPE.mpeClassTag)
}
}
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
package com.dwolla.util.async.finagle

import com.twitter.finagle.service.RetryBudget
import com.twitter.finagle.stats.{DefaultStatsReceiver, StatsReceiver}
import com.twitter.finagle.tracing.{DefaultTracer, Tracer}
import com.twitter.util.Duration

Expand All @@ -10,19 +11,22 @@ class ThriftClientConfiguration private(val requestTimeout: Duration,
val sessionPoolMax: Int,
val retryBudget: RetryBudget,
val tracer: Tracer,
val statsReceiver: StatsReceiver,
) {
def withRequestTimeout(x: Duration): ThriftClientConfiguration =
new ThriftClientConfiguration(x, sessionAcquisitionTimeout, transportConnectTimeout, sessionPoolMax, retryBudget, tracer)
new ThriftClientConfiguration(x, sessionAcquisitionTimeout, transportConnectTimeout, sessionPoolMax, retryBudget, tracer, statsReceiver)
def withSessionAcquisitionTimeout(x: Duration): ThriftClientConfiguration =
new ThriftClientConfiguration(requestTimeout, x, transportConnectTimeout, sessionPoolMax, retryBudget, tracer)
new ThriftClientConfiguration(requestTimeout, x, transportConnectTimeout, sessionPoolMax, retryBudget, tracer, statsReceiver)
def withTransportConnectTimeout(x: Duration): ThriftClientConfiguration =
new ThriftClientConfiguration(requestTimeout, sessionAcquisitionTimeout, x, sessionPoolMax, retryBudget, tracer)
new ThriftClientConfiguration(requestTimeout, sessionAcquisitionTimeout, x, sessionPoolMax, retryBudget, tracer, statsReceiver)
def withSessionPoolMax(x: Int): ThriftClientConfiguration =
new ThriftClientConfiguration(requestTimeout, sessionAcquisitionTimeout, transportConnectTimeout, x, retryBudget, tracer)
new ThriftClientConfiguration(requestTimeout, sessionAcquisitionTimeout, transportConnectTimeout, x, retryBudget, tracer, statsReceiver)
def withRetryBudget(x: RetryBudget): ThriftClientConfiguration =
new ThriftClientConfiguration(requestTimeout, sessionAcquisitionTimeout, transportConnectTimeout, sessionPoolMax, x, tracer)
new ThriftClientConfiguration(requestTimeout, sessionAcquisitionTimeout, transportConnectTimeout, sessionPoolMax, x, tracer, statsReceiver)
def withTracer(x: Tracer): ThriftClientConfiguration =
new ThriftClientConfiguration(requestTimeout, sessionAcquisitionTimeout, transportConnectTimeout, sessionPoolMax, retryBudget, x)
new ThriftClientConfiguration(requestTimeout, sessionAcquisitionTimeout, transportConnectTimeout, sessionPoolMax, retryBudget, x, statsReceiver)
def withStatsReceiver(x: StatsReceiver): ThriftClientConfiguration =
new ThriftClientConfiguration(requestTimeout, sessionAcquisitionTimeout, transportConnectTimeout, sessionPoolMax, retryBudget, tracer, x)
}

object ThriftClientConfiguration {
Expand All @@ -33,5 +37,6 @@ object ThriftClientConfiguration {
50,
RetryBudget.Empty,
DefaultTracer,
DefaultStatsReceiver
)
}

0 comments on commit aa5c3bc

Please sign in to comment.