Documentation ¶
Index ¶
- Constants
- Variables
- func RegisterPlugin(name string, plugin Plugin)
- func SetPluginConfig(c *Config)
- type AddCheckRequest
- type CMDB
- type CheckRequest
- type CheckResponse
- type CompositeDiscoverChannel
- type CompositeHistory
- type Config
- type ConfigEntry
- type DiscoverChannel
- type DiscoverStatis
- type HealthCheckType
- type HealthChecker
- type History
- type ParsePassword
- type Plugin
- type PluginChanConfig
- type QueryRequest
- type QueryResponse
- type Ratelimit
- type RatelimitType
- type ReportRequest
- type Statis
- type Whitelist
Constants ¶
const ( ComponentServer = "server" ComponentRedis = "redis" ComponentProtobufCache = "protobuf" )
Variables ¶
var RatelimitStr = map[RatelimitType]string{ IPRatelimit: "ip-limit", APIRatelimit: "api-limit", ServiceRatelimit: "service-limit", InstanceRatelimit: "instance-limit", }
RatelimitStr rate limit string map
Functions ¶
Types ¶
type AddCheckRequest ¶
AddCheckRequest add check request
type CMDB ¶
type CMDB interface { Plugin // GetLocation 在CMDB中没有找到Host,返回error为nil,location为nil // 插件内部出现错误,返回error不为nil,忽略location GetLocation(host string) (*model.Location, error) // Range 提供一个Range接口,遍历所有的数据 // 遍历失败,通过Range返回值error可以额捕获 // 参数为一个回调函数 // 返回值:bool,是否继续遍历 // 返回值:error,回调函数处理结果,error不为nil,则停止遍历过程,并且通过Range返回error Range(handler func(host string, location *model.Location) (bool, error)) error // Size 获取当前CMDB存储的entry个数 Size() int32 }
CMDB CMDB插件接口
type CheckRequest ¶
type CheckRequest struct { QueryRequest ExpireDurationSec uint32 CurTimeSec func() int64 }
CheckRequest check heartbeat request
type CheckResponse ¶
type CheckResponse struct { Healthy bool LastHeartbeatTimeSec int64 StayUnchanged bool Regular bool }
CheckResponse check heartbeat response
type CompositeDiscoverChannel ¶ added in v1.14.0
type CompositeDiscoverChannel struct {
// contains filtered or unexported fields
}
CompositeDiscoverChannel is used to receive discover events from the agent
func (*CompositeDiscoverChannel) Destroy ¶ added in v1.14.0
func (c *CompositeDiscoverChannel) Destroy() error
func (*CompositeDiscoverChannel) Initialize ¶ added in v1.14.0
func (c *CompositeDiscoverChannel) Initialize(config *ConfigEntry) error
func (*CompositeDiscoverChannel) Name ¶ added in v1.14.0
func (c *CompositeDiscoverChannel) Name() string
func (*CompositeDiscoverChannel) PublishEvent ¶ added in v1.14.0
func (c *CompositeDiscoverChannel) PublishEvent(event model.InstanceEvent)
PublishEvent Release a service event
type CompositeHistory ¶ added in v1.14.0
type CompositeHistory struct {
// contains filtered or unexported fields
}
func (*CompositeHistory) Destroy ¶ added in v1.14.0
func (c *CompositeHistory) Destroy() error
func (*CompositeHistory) Initialize ¶ added in v1.14.0
func (c *CompositeHistory) Initialize(config *ConfigEntry) error
func (*CompositeHistory) Name ¶ added in v1.14.0
func (c *CompositeHistory) Name() string
func (*CompositeHistory) Record ¶ added in v1.14.0
func (c *CompositeHistory) Record(entry *model.RecordEntry)
type Config ¶
type Config struct { CMDB ConfigEntry `yaml:"cmdb"` RateLimit ConfigEntry `yaml:"ratelimit"` History PluginChanConfig `yaml:"history"` Statis ConfigEntry `yaml:"statis"` DiscoverStatis ConfigEntry `yaml:"discoverStatis"` ParsePassword ConfigEntry `yaml:"parsePassword"` Whitelist ConfigEntry `yaml:"whitelist"` MeshResourceValidate ConfigEntry `yaml:"meshResourceValidate"` DiscoverEvent PluginChanConfig `yaml:"discoverEvent"` }
Config 插件配置
type ConfigEntry ¶
ConfigEntry 单个插件配置
type DiscoverChannel ¶
type DiscoverChannel interface { Plugin // PublishEvent Release a service event PublishEvent(event model.InstanceEvent) }
DiscoverChannel is used to receive discover events from the agent
func GetDiscoverEvent ¶
func GetDiscoverEvent() DiscoverChannel
GetDiscoverEvent Get service discovery event plug -in
type DiscoverStatis ¶
type DiscoverStatis interface { Plugin // AddDiscoverCall Add found call AddDiscoverCall(service, namespace string, tt time.Time) error }
DiscoverStatis Service discovery statistical plug -in interface
func GetDiscoverStatis ¶
func GetDiscoverStatis() DiscoverStatis
GetDiscoverStatis Get service discovery statistical plug -in
type HealthCheckType ¶
type HealthCheckType int32
HealthCheckType health check type
const (
HealthCheckerHeartbeat HealthCheckType = iota + 1
)
type HealthChecker ¶
type HealthChecker interface { Plugin // Type for health check plugin, only one same type plugin is allowed Type() HealthCheckType // Report process heartbeat info report Report(request *ReportRequest) error // Check process the instance check Check(request *CheckRequest) (*CheckResponse, error) // Query queries the heartbeat time Query(request *QueryRequest) (*QueryResponse, error) // AddToCheck add the instances to check procedure AddToCheck(request *AddCheckRequest) error // RemoveFromCheck removes the instances from check procedure RemoveFromCheck(request *AddCheckRequest) error // Delete delete the id Delete(id string) error }
HealthChecker health checker plugin interface
func GetHealthChecker ¶
func GetHealthChecker(name string, cfg *ConfigEntry) HealthChecker
GetHealthChecker get the health checker by name
type ParsePassword ¶
ParsePassword Password plug -in
func GetParsePassword ¶
func GetParsePassword() ParsePassword
GetParsePassword Get the parsing password plug -in
type Plugin ¶
type Plugin interface { Name() string Initialize(c *ConfigEntry) error Destroy() error }
Plugin 通用插件接口
type PluginChanConfig ¶ added in v1.14.0
type PluginChanConfig struct { ConfigEntry Entries []ConfigEntry }
PluginChanConfig 插件执行链配置
type QueryRequest ¶
QueryRequest query heartbeat request
type QueryResponse ¶
QueryResponse query heartbeat response
type Ratelimit ¶
type Ratelimit interface { Plugin // Allow Whether to allow access, true: allow, FALSE: not allowing Todo // - Parameter ratingype is the type of current limits, and the ID is the key that limits the current // - If RateType is Ratelimitip, the ID is IP, RateType is Ratelimitservice, and the ID is // IP_NAMESPACE_SERVICE or IP_SERVICEID Allow(typ RatelimitType, key string) bool }
Ratelimit Ratelimit plugin interface
type RatelimitType ¶
type RatelimitType int
RatelimitType rate limit type
const ( // IPRatelimit Based on IP flow control IPRatelimit RatelimitType = iota + 1 // APIRatelimit Based on interface-level flow control APIRatelimit // ServiceRatelimit Based on Service flow control ServiceRatelimit // InstanceRatelimit Based on Instance flow control InstanceRatelimit )
type ReportRequest ¶
type ReportRequest struct { QueryRequest LocalHost string CurTimeSec int64 }
ReportRequest report heartbeat request