errorrate

package
v0.1.2 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jul 29, 2022 License: MIT, Apache-2.0, BSD-2-Clause, + 4 more Imports: 15 Imported by: 0

Documentation

Index

Constants

View Source
const (
	// 只有请求数达到某个阈值才执行熔断计算,默认10
	DefaultRequestVolumeThreshold = 10
	// 触发熔断的错误率阈值,默认0.5
	DefaultErrorRateThreshold float64 = 0.5
	// 默认错误率百分比
	DefaultErrorRatePercent int = 50
	// 最大错误率百分比
	MaxErrorRatePercent int = 100
	// 错误率统计时间窗口,默认1分钟
	DefaultMetricStatTimeWindow = 60 * time.Second
	// 最小错误率统计时间窗口,1s
	MinMetricStatTimeWindow = 1 * time.Second
	// 统计窗口细分的桶数量,默认10
	DefaultMetricNumBuckets = 5
	// 最小的滑窗时间片,1ms
	MinMetricStatBucketSize = 1 * time.Millisecond
)

定义错误率熔断配置的默认值

Variables

This section is empty.

Functions

func ToErrorRateThreshold

func ToErrorRateThreshold(errorRatePercent int) float64

ToErrorRateThreshold 转换成熔断错误率阈值

Types

type CircuitBreaker

type CircuitBreaker struct {
	*plugin.PluginBase
	// contains filtered or unexported fields
}

CircuitBreaker 基于错误率的默认熔断规则

func (*CircuitBreaker) CircuitBreak

func (g *CircuitBreaker) CircuitBreak(instances []model.Instance) (*circuitbreaker.Result, error)

CircuitBreak .熔断 定期进行熔断计算,返回需要进行状态转换的实例ID 入参包括全量服务实例,以及当前周期的健康探测结果

func (*CircuitBreaker) Destroy

func (g *CircuitBreaker) Destroy() error

Destroy 销毁插件,可用于释放资源

func (*CircuitBreaker) Init

func (g *CircuitBreaker) Init(ctx *plugin.InitContext) error

Init 初始化插件

func (*CircuitBreaker) IsEnable

func (g *CircuitBreaker) IsEnable(cfg config.Configuration) bool

IsEnable enable

func (*CircuitBreaker) Name

func (g *CircuitBreaker) Name() string

Name 插件名,一个类型下插件名唯一

func (*CircuitBreaker) Stat

func (g *CircuitBreaker) Stat(gauge model.InstanceGauge) (bool, error)

Stat 实时上报健康状态并进行失败率统计

func (*CircuitBreaker) Type

func (g *CircuitBreaker) Type() common2.Type

Type 插件类型

type Config

type Config struct {
	RequestVolumeThreshold int `yaml:"requestVolumeThreshold" json:"requestVolumeThreshold"`
	ErrorRatePercent       int `yaml:"errorRatePercent" json:"errorRatePercent"`
	// Deprecated, 请使用ErrorRatePercent
	ErrorRateThreshold   float64        `yaml:"errorRateThreshold" json:"errorRateThreshold"`
	MetricStatTimeWindow *time.Duration `yaml:"metricStatTimeWindow" json:"metricStatTimeWindow"`
	MetricNumBuckets     int            `yaml:"metricNumBuckets" json:"metricNumBuckets"`
}

基于错误率熔断器的配置结构

func (*Config) GetBucketInterval

func (r *Config) GetBucketInterval() time.Duration

获取滑桶时间间隔

func (*Config) GetErrorRatePercent

func (r *Config) GetErrorRatePercent() int

触发熔断的错误率阈值,取值范围(0, 100]

func (*Config) GetMetricNumBuckets

func (r *Config) GetMetricNumBuckets() int

统计窗口细分的桶数量

func (*Config) GetMetricStatTimeWindow

func (r *Config) GetMetricStatTimeWindow() time.Duration

错误率统计时间窗口

func (*Config) GetRequestVolumeThreshold

func (r *Config) GetRequestVolumeThreshold() int

触发错误率熔断的请求量阈值

func (*Config) SetDefault

func (r *Config) SetDefault()

设置错误率熔断配置的默认值

func (*Config) SetErrorRatePercent

func (r *Config) SetErrorRatePercent(value int)

设置错误率阈值

func (*Config) SetMetricNumBuckets

func (r *Config) SetMetricNumBuckets(value int)

设置统计窗口细分的桶数量

func (*Config) SetMetricStatTimeWindow

func (r *Config) SetMetricStatTimeWindow(value time.Duration)

设置错误率统计时间窗口

func (*Config) SetRequestVolumeThreshold

func (r *Config) SetRequestVolumeThreshold(value int)

设置触发错误率熔断的请求量阈值

func (*Config) Verify

func (r *Config) Verify() error

检验错误率熔断配置

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL