| 
									
										
										
										
											2024-09-16 11:06:00 +02:00
										 |  |  | /* | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Copyright 2024 gRPC authors. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Licensed under the Apache License, Version 2.0 (the "License"); | 
					
						
							|  |  |  |  * you may not use this file except in compliance with the License. | 
					
						
							|  |  |  |  * You may obtain a copy of the License at | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *     http://www.apache.org/licenses/LICENSE-2.0 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Unless required by applicable law or agreed to in writing, software | 
					
						
							|  |  |  |  * distributed under the License is distributed on an "AS IS" BASIS, | 
					
						
							|  |  |  |  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
					
						
							|  |  |  |  * See the License for the specific language governing permissions and | 
					
						
							|  |  |  |  * limitations under the License. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Package stats contains experimental metrics/stats API's. | 
					
						
							|  |  |  | package stats | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-02-06 12:14:37 +01:00
										 |  |  | import "google.golang.org/grpc/stats" | 
					
						
							| 
									
										
										
										
											2024-09-16 11:06:00 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | // MetricsRecorder records on metrics derived from metric registry. | 
					
						
							|  |  |  | type MetricsRecorder interface { | 
					
						
							|  |  |  | 	// RecordInt64Count records the measurement alongside labels on the int | 
					
						
							|  |  |  | 	// count associated with the provided handle. | 
					
						
							|  |  |  | 	RecordInt64Count(handle *Int64CountHandle, incr int64, labels ...string) | 
					
						
							|  |  |  | 	// RecordFloat64Count records the measurement alongside labels on the float | 
					
						
							|  |  |  | 	// count associated with the provided handle. | 
					
						
							|  |  |  | 	RecordFloat64Count(handle *Float64CountHandle, incr float64, labels ...string) | 
					
						
							|  |  |  | 	// RecordInt64Histo records the measurement alongside labels on the int | 
					
						
							|  |  |  | 	// histo associated with the provided handle. | 
					
						
							|  |  |  | 	RecordInt64Histo(handle *Int64HistoHandle, incr int64, labels ...string) | 
					
						
							|  |  |  | 	// RecordFloat64Histo records the measurement alongside labels on the float | 
					
						
							|  |  |  | 	// histo associated with the provided handle. | 
					
						
							|  |  |  | 	RecordFloat64Histo(handle *Float64HistoHandle, incr float64, labels ...string) | 
					
						
							|  |  |  | 	// RecordInt64Gauge records the measurement alongside labels on the int | 
					
						
							|  |  |  | 	// gauge associated with the provided handle. | 
					
						
							|  |  |  | 	RecordInt64Gauge(handle *Int64GaugeHandle, incr int64, labels ...string) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-02-06 12:14:37 +01:00
										 |  |  | // Metrics is an experimental legacy alias of the now-stable stats.MetricSet. | 
					
						
							|  |  |  | // Metrics will be deleted in a future release. | 
					
						
							|  |  |  | type Metrics = stats.MetricSet | 
					
						
							| 
									
										
										
										
											2024-09-16 11:06:00 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-02-06 12:14:37 +01:00
										 |  |  | // Metric was replaced by direct usage of strings. | 
					
						
							|  |  |  | type Metric = string | 
					
						
							| 
									
										
										
										
											2024-09-16 11:06:00 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-02-06 12:14:37 +01:00
										 |  |  | // NewMetrics is an experimental legacy alias of the now-stable | 
					
						
							|  |  |  | // stats.NewMetricSet.  NewMetrics will be deleted in a future release. | 
					
						
							| 
									
										
										
										
											2024-09-16 11:06:00 +02:00
										 |  |  | func NewMetrics(metrics ...Metric) *Metrics { | 
					
						
							| 
									
										
										
										
											2025-02-06 12:14:37 +01:00
										 |  |  | 	return stats.NewMetricSet(metrics...) | 
					
						
							| 
									
										
										
										
											2024-09-16 11:06:00 +02:00
										 |  |  | } |