Documentation ¶
Overview ¶
+kubebuilder:validation:Optional
Index ¶
Constants ¶
const ( // SignalReadingMetricName - used in circuit metrics. SignalReadingMetricName = "signal_reading" // FluxMeterMetricName name of fluxmeter metrics. FluxMeterMetricName = "flux_meter" // WorkloadLatencyMetricName - metric used for grouping latencies per workload. WorkloadLatencyMetricName = "workload_latency_ms" // RequestCounterMetricName - metric from http server. RequestCounterMetricName = "http_server_request_counter" // ErrorCountMetricName - metric from http server. ErrorCountMetricName = "http_server_error_counter" // LatencyHistogramMetricName - metric from http server. LatencyHistogramMetricName = "http_server_request_latency_seconds" // AcceptedConcurrencyMetricName - metric for measuring latencies of accepted requests. AcceptedConcurrencyMetricName = "accepted_concurrency" // IncomingConcurrencyMetricName - metric for measuring latencies of all incoming requests. IncomingConcurrencyMetricName = "incoming_concurrency" // WorkloadLatencySumMetricName - metric from workload histogram. WorkloadLatencySumMetricName = "workload_latency_ms_sum" // WorkloadLatencyCountMetricName - metric from workload histogram. WorkloadLatencyCountMetricName = "workload_latency_ms_count" // WFQFlowsMetricName - weighted fair queuing number of flows gauge. WFQFlowsMetricName = "wfq_flows" // WFQRequestsMetricName - weighted fair queuing number of requests gauge. WFQRequestsMetricName = "wfq_requests" // FlowControlRequestsMetricName - counter for Check requests for flowcontrol. FlowControlRequestsMetricName = "flowcontrol_requests_count" // FlowControlDecisionsMetricName - counter for Check requests per decision type. FlowControlDecisionsMetricName = "flowcontrol_decisions_count" // FlowControlErrorReasonMetricName - metric for error reason on FCS Check requests. FlowControlErrorReasonMetricName = "flowcontrol_error_reason_count" // FlowControlRejectReasonMetricName - metric for reject reason on FCS Check requests. FlowControlRejectReasonMetricName = "flowcontrol_reject_reason_count" // TokenBucketMetricName - a gauge that tracks the load shed factor. TokenBucketMetricName = "token_bucket_lsf" // TokenBucketFillRateMetricName - a gauge that tracks the fill rate of token bucket. TokenBucketFillRateMetricName = "token_bucket_fill_rate" // TokenBucketCapacityMetricName - a gauge that tracks the capacity of token bucket. TokenBucketCapacityMetricName = "token_bucket_capacity" // TokenBucketAvailableMetricName - a gauge that tracks the number of tokens available in token bucket. TokenBucketAvailableMetricName = "token_bucket_available_tokens" // PolicyNameLabel - label used in prometheus. PolicyNameLabel = "policy_name" // PolicyHashLabel - label used in prometheus. PolicyHashLabel = "policy_hash" // ComponentIndexLabel - index of component in circuit label. ComponentIndexLabel = "component_index" // DecisionTypeLabel - label for decision type dropped or accepted. DecisionTypeLabel = "decision_type" // WorkloadIndexLabel - label for choosing correct workload. WorkloadIndexLabel = "workload_index" // SignalNameLabel - label for saving circuit signal metrics. SignalNameLabel = "signal_name" // FluxMeterNameLabel - specifying flux meter's name. FluxMeterNameLabel = "flux_meter_name" // ClassifierIndexLabel - prometheus label specifying clasiffier index. ClassifierIndexLabel = "classifier_index" // StatusCodeLabel - http status code. StatusCodeLabel = "status_code" // FeatureStatusLabel - feature status. FeatureStatusLabel = "feature_status" // MethodLabel - label from http method. MethodLabel = "method" // ResponseStatusCodeLabel - label from response status code. ResponseStatusCodeLabel = "response_status_code" // FlowControlCheckDecisionTypeLabel - label for decision type dropped or accepted. FlowControlCheckDecisionTypeLabel = "decision_type" // FlowControlCheckErrorReasonLabel - label for error reason on FCS Check request. FlowControlCheckErrorReasonLabel = "error_reason" // FlowControlCheckRejectReasonLabel - label for reject reason on FCS Check request. FlowControlCheckRejectReasonLabel = "reject_reason" // DefaultWorkloadIndex - when workload is not specified this value is used. DefaultWorkloadIndex = "default" // DefaultAgentGroup - default agent group. DefaultAgentGroup = "default" )
Variables ¶
This section is empty.
Functions ¶
func Module ¶
Module is a fx module that provides Prometheus registry and invokes registering metrics handler.
func ProvidePrometheusRegistry ¶
func ProvidePrometheusRegistry(unmarshaller config.Unmarshaller) (*prometheus.Registry, error)
ProvidePrometheusRegistry creates a new Prometheus Registry and provides it via Fx. Metrics from the Registry are served on /metrics via the default http server of Fx application.
func RegisterMetricsHandler ¶
func RegisterMetricsHandler(router *mux.Router, pr *prometheus.Registry)
RegisterMetricsHandler registers the metrics handler on the promhttp server.
Types ¶
type MetricsConfig ¶
type MetricsConfig struct { // Pedantic controls whether a pedantic Registerer is used as the prometheus backend. See <https://godoc.org/github.com/prometheus/client_golang/prometheus#NewPedanticRegistry> Pedantic bool `json:"pedantic" default:"false"` // EnableGoCollector controls whether the go collector is registered on startup. See <https://godoc.org/github.com/prometheus/client_golang/prometheus#NewGoCollector> EnableGoCollector bool `json:"enable_go_metrics" default:"false"` // EnableProcessCollector controls whether the process collector is registered on startup. See <https://godoc.org/github.com/prometheus/client_golang/prometheus#NewProcessCollector> EnableProcessCollector bool `json:"enable_process_collector" default:"false"` }
MetricsConfig holds configuration for service metrics. swagger:model +kubebuilder:object:generate=true
func (*MetricsConfig) DeepCopy ¶ added in v0.1.2
func (in *MetricsConfig) DeepCopy() *MetricsConfig
DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new MetricsConfig.
func (*MetricsConfig) DeepCopyInto ¶ added in v0.1.2
func (in *MetricsConfig) DeepCopyInto(out *MetricsConfig)
DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil.