1
0
mirror of https://github.com/v2fly/v2ray-core.git synced 2025-01-02 15:36:41 -05:00
v2fly/infra/conf/synthetic/router/router_strategy.go

104 lines
2.9 KiB
Go
Raw Normal View History

2021-06-19 08:28:20 -04:00
package router
2021-04-08 16:08:20 -04:00
import (
"github.com/golang/protobuf/proto"
2021-10-28 06:34:19 -04:00
"github.com/v2fly/v2ray-core/v4/app/observatory/burst"
2021-10-28 06:34:19 -04:00
"github.com/v2fly/v2ray-core/v4/app/router"
2021-06-19 08:28:20 -04:00
"github.com/v2fly/v2ray-core/v4/infra/conf/cfgcommon/duration"
"github.com/v2fly/v2ray-core/v4/infra/conf/cfgcommon/loader"
)
2021-04-08 16:08:20 -04:00
const (
strategyRandom string = "random"
strategyLeastLoad string = "leastload"
2021-04-08 16:08:20 -04:00
strategyLeastPing string = "leastping"
)
var (
2021-06-19 08:28:20 -04:00
strategyConfigLoader = loader.NewJSONConfigLoader(loader.ConfigCreatorCache{
strategyRandom: func() interface{} { return new(strategyEmptyConfig) },
strategyLeastLoad: func() interface{} { return new(strategyLeastLoadConfig) },
strategyLeastPing: func() interface{} { return new(strategyLeastPingConfig) },
}, "type", "settings")
)
type strategyEmptyConfig struct {
}
func (v *strategyEmptyConfig) Build() (proto.Message, error) {
return nil, nil
}
type strategyLeastLoadConfig struct {
// weight settings
Costs []*router.StrategyWeight `json:"costs,omitempty"`
2021-06-05 08:00:14 -04:00
// ping rtt baselines
2021-06-19 08:28:20 -04:00
Baselines []duration.Duration `json:"baselines,omitempty"`
// expected nodes count to select
Expected int32 `json:"expected,omitempty"`
2021-06-05 08:00:14 -04:00
// max acceptable rtt, filter away high delay nodes. defalut 0
2021-06-19 08:28:20 -04:00
MaxRTT duration.Duration `json:"maxRTT,omitempty"`
// acceptable failure rate
Tolerance float64 `json:"tolerance,omitempty"`
ObserverTag string `json:"observerTag,omitempty"`
}
2021-06-19 08:28:20 -04:00
// HealthCheckSettings holds settings for health Checker
type HealthCheckSettings struct {
Destination string `json:"destination"`
Connectivity string `json:"connectivity"`
Interval duration.Duration `json:"interval"`
SamplingCount int `json:"sampling"`
Timeout duration.Duration `json:"timeout"`
2021-06-05 08:00:14 -04:00
}
2021-06-19 08:28:20 -04:00
func (h HealthCheckSettings) Build() (proto.Message, error) {
return &burst.HealthPingConfig{
Destination: h.Destination,
Connectivity: h.Connectivity,
Interval: int64(h.Interval),
Timeout: int64(h.Timeout),
SamplingCount: int32(h.SamplingCount),
}, nil
}
// Build implements Buildable.
func (v *strategyLeastLoadConfig) Build() (proto.Message, error) {
config := &router.StrategyLeastLoadConfig{}
config.Costs = v.Costs
config.Tolerance = float32(v.Tolerance)
config.ObserverTag = v.ObserverTag
if config.Tolerance < 0 {
config.Tolerance = 0
}
if config.Tolerance > 1 {
config.Tolerance = 1
}
config.Expected = v.Expected
if config.Expected < 0 {
config.Expected = 0
}
2021-06-05 08:00:14 -04:00
config.MaxRTT = int64(v.MaxRTT)
if config.MaxRTT < 0 {
config.MaxRTT = 0
}
config.Baselines = make([]int64, 0)
for _, b := range v.Baselines {
if b <= 0 {
continue
}
2021-06-05 08:00:14 -04:00
config.Baselines = append(config.Baselines, int64(b))
}
return config, nil
}
type strategyLeastPingConfig struct {
ObserverTag string `json:"observerTag,omitempty"`
}
func (s strategyLeastPingConfig) Build() (proto.Message, error) {
return &router.StrategyLeastPingConfig{ObserverTag: s.ObserverTag}, nil
}