- 
                Notifications
    You must be signed in to change notification settings 
- Fork 4.6k
experimental/stats: Add up down counter for A94 #8581
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
| Original file line number | Diff line number | Diff line change | 
|---|---|---|
|  | @@ -75,6 +75,7 @@ const ( | |
| MetricTypeIntHisto | ||
| MetricTypeFloatHisto | ||
| MetricTypeIntGauge | ||
| MetricTypeIntUpDownCount | ||
| ) | ||
|  | ||
| // Int64CountHandle is a typed handle for a int count metric. This handle | ||
|  | @@ -93,6 +94,23 @@ func (h *Int64CountHandle) Record(recorder MetricsRecorder, incr int64, labels . | |
| recorder.RecordInt64Count(h, incr, labels...) | ||
| } | ||
|  | ||
| // Int64UpDownCountHandle is a typed handle for an int up-down counter metric. | ||
| There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I understand this docstring is very similar to the existing one for  There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. It's a newtype for MetricDescriptor - all different metric types have the same Descriptor information, but we give them all their own types so that they can be used correctly. (I.e. they have proper method signatures on  | ||
| // This handle is passed at the recording point in order to know which metric | ||
| // to record on. | ||
| type Int64UpDownCountHandle MetricDescriptor | ||
|  | ||
| // Descriptor returns the int64 up-down counter handle typecast to a pointer to a | ||
| // MetricDescriptor. | ||
| func (h *Int64UpDownCountHandle) Descriptor() *MetricDescriptor { | ||
| return (*MetricDescriptor)(h) | ||
| } | ||
|  | ||
| // Record records the int64 up-down counter value on the metrics recorder provided. | ||
| // The value 'v' can be positive to increment or negative to decrement. | ||
| func (h *Int64UpDownCountHandle) Record(recorder MetricsRecorder, v int64, labels ...string) { | ||
| recorder.RecordInt64UpDownCount(h, v, labels...) | ||
| } | ||
|  | ||
| // Float64CountHandle is a typed handle for a float count metric. This handle is | ||
| // passed at the recording point in order to know which metric to record on. | ||
| type Float64CountHandle MetricDescriptor | ||
|  | @@ -249,6 +267,21 @@ func RegisterInt64Gauge(descriptor MetricDescriptor) *Int64GaugeHandle { | |
| return (*Int64GaugeHandle)(descPtr) | ||
| } | ||
|  | ||
| // RegisterInt64UpDownCount registers the metric description onto the global registry. | ||
| // It returns a typed handle to use for recording data. | ||
| // | ||
| // NOTE: this function must only be called during initialization time (i.e. in | ||
| // an init() function), and is not thread-safe. If multiple metrics are | ||
| // registered with the same name, this function will panic. | ||
| func RegisterInt64UpDownCount(descriptor MetricDescriptor) *Int64UpDownCountHandle { | ||
| registerMetric(descriptor.Name, descriptor.Default) | ||
| // Set the specific metric type for the up-down counter | ||
| descriptor.Type = MetricTypeIntUpDownCount | ||
| descPtr := &descriptor | ||
| metricsRegistry[descriptor.Name] = descPtr | ||
| return (*Int64UpDownCountHandle)(descPtr) | ||
| } | ||
|  | ||
| // snapshotMetricsRegistryForTesting snapshots the global data of the metrics | ||
| // registry. Returns a cleanup function that sets the metrics registry to its | ||
| // original state. | ||
|  | ||
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What happens if
incris negative here?