mirror of https://github.com/knative/pkg.git
				
				
				
			
		
			
				
	
	
		
			112 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Go
		
	
	
	
			
		
		
	
	
			112 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Go
		
	
	
	
/*
 | 
						|
Copyright 2021 The Knative 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 metrics
 | 
						|
 | 
						|
import (
 | 
						|
	"context"
 | 
						|
 | 
						|
	"go.opencensus.io/stats/view"
 | 
						|
	"go.uber.org/zap"
 | 
						|
	"knative.dev/pkg/logging"
 | 
						|
)
 | 
						|
 | 
						|
type metricsWorker struct {
 | 
						|
	c chan command
 | 
						|
}
 | 
						|
 | 
						|
func newMetricsWorker() *metricsWorker {
 | 
						|
	return &metricsWorker{c: make(chan command)}
 | 
						|
}
 | 
						|
 | 
						|
type command interface {
 | 
						|
	handleCommand(w *metricsWorker)
 | 
						|
}
 | 
						|
 | 
						|
type readExporter struct {
 | 
						|
	done chan *view.Exporter
 | 
						|
}
 | 
						|
 | 
						|
type setExporter struct {
 | 
						|
	newExporter *view.Exporter
 | 
						|
	done        chan struct{}
 | 
						|
}
 | 
						|
 | 
						|
type readMetricsConfig struct {
 | 
						|
	done chan *metricsConfig
 | 
						|
}
 | 
						|
 | 
						|
type updateMetricsConfigWithExporter struct {
 | 
						|
	ctx       context.Context
 | 
						|
	newConfig *metricsConfig
 | 
						|
	done      chan error
 | 
						|
}
 | 
						|
 | 
						|
type setMetricsConfig struct {
 | 
						|
	newConfig *metricsConfig
 | 
						|
	done      chan struct{}
 | 
						|
}
 | 
						|
 | 
						|
func (cmd *readMetricsConfig) handleCommand(w *metricsWorker) {
 | 
						|
	cmd.done <- curMetricsConfig
 | 
						|
}
 | 
						|
 | 
						|
func (cmd *setMetricsConfig) handleCommand(w *metricsWorker) {
 | 
						|
	setCurMetricsConfigUnlocked(cmd.newConfig)
 | 
						|
	cmd.done <- struct{}{}
 | 
						|
}
 | 
						|
 | 
						|
func (cmd *updateMetricsConfigWithExporter) handleCommand(w *metricsWorker) {
 | 
						|
	ctx := cmd.ctx
 | 
						|
	logger := logging.FromContext(ctx)
 | 
						|
	if isNewExporterRequired(cmd.newConfig) {
 | 
						|
		logger.Info("Flushing the existing exporter before setting up the new exporter.")
 | 
						|
		flushGivenExporter(curMetricsExporter)
 | 
						|
		e, f, err := newMetricsExporter(cmd.newConfig, logger)
 | 
						|
		if err != nil {
 | 
						|
			logger.Errorw("Failed to update a new metrics exporter based on metric config", zap.Error(err), "config", cmd.newConfig)
 | 
						|
			cmd.done <- err
 | 
						|
			return
 | 
						|
		}
 | 
						|
		existingConfig := curMetricsConfig
 | 
						|
		curMetricsExporter = e
 | 
						|
		if err := setFactory(f); err != nil {
 | 
						|
			logger.Errorw("Failed to update metrics factory when loading metric config", zap.Error(err), "config", cmd.newConfig)
 | 
						|
			cmd.done <- err
 | 
						|
			return
 | 
						|
		}
 | 
						|
		logger.Infof("Successfully updated the metrics exporter; old config: %v; new config %v", existingConfig, cmd.newConfig)
 | 
						|
	}
 | 
						|
	setCurMetricsConfigUnlocked(cmd.newConfig)
 | 
						|
	cmd.done <- nil
 | 
						|
}
 | 
						|
 | 
						|
func (w *metricsWorker) start() {
 | 
						|
	for {
 | 
						|
		cmd := <-w.c
 | 
						|
		cmd.handleCommand(w)
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func (cmd *setExporter) handleCommand(w *metricsWorker) {
 | 
						|
	curMetricsExporter = *cmd.newExporter
 | 
						|
	cmd.done <- struct{}{}
 | 
						|
}
 | 
						|
 | 
						|
func (cmd *readExporter) handleCommand(w *metricsWorker) {
 | 
						|
	cmd.done <- &curMetricsExporter
 | 
						|
}
 |