datasource

package
v1.2.3 Latest Latest
Warning

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

Go to latest
Published: Dec 26, 2024 License: MIT Imports: 25 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func DomainEval added in v1.1.0

func DomainEval(_ context.Context, domain string, port uint32, timeout time.Duration) (map[watch.Indexer]*Point, error)

DomainEval 函数用于获取域名的证书信息,并返回一个 map[Indexer]*Point 结构

其中 Indexer 是一个标签,用于标识一个数据点,Point 是一个数据点,包含标签和值。

func EndpointDuration added in v1.1.0

func EndpointDuration(ctx context.Context, url string, method vobj.HTTPMethod, headers map[string]string, body string, timeout time.Duration) map[watch.Indexer]*Point

EndpointDuration 函数用于获取指定endpoint的请求相应时间和状态码

func EndpointPing added in v1.1.0

func EndpointPing(_ context.Context, endpoint string, seconds time.Duration) (map[watch.Indexer]*Point, error)

EndpointPing 是ping探测器的实现

func EndpointPortEval added in v1.1.0

func EndpointPortEval(_ context.Context, endpoint string, port uint32, timeout time.Duration) (map[watch.Indexer]*Point, error)

EndpointPortEval 函数用于获取指定 endpoint 端口的监控数据, 用于检查端口是否正常

Types

type BasicAuth

type BasicAuth struct {
	Username string `json:"username"`
	Password string `json:"password"`
}

BasicAuth 基础认证信息

type BasicInfo added in v1.0.2

type BasicInfo struct {
	Endpoint  string     `json:"endpoint"`
	ID        uint32     `json:"id"`
	BasicAuth *BasicAuth `json:"basic_auth"`
}

BasicInfo 数据源信息

type Config added in v1.2.0

type Config struct {
	// contains filtered or unexported fields
}

Config 数据源配置

func NewDatasourceConfig added in v1.2.0

func NewDatasourceConfig(datasourceConfig map[string]any) *Config

NewDatasourceConfig 基于map创建DatasourceConfig

func NewDatasourceConfigByString added in v1.2.0

func NewDatasourceConfigByString(datasourceConfig string) *Config

NewDatasourceConfigByString 基于string创建DatasourceConfig

func (*Config) GetKafka added in v1.2.0

func (d *Config) GetKafka() *conf.Kafka

GetKafka 获取Kafka配置

func (*Config) GetMQTT added in v1.2.0

func (d *Config) GetMQTT() *conf.MQTT

GetMQTT 获取MQTT配置

func (*Config) GetRocketMQ added in v1.2.0

func (d *Config) GetRocketMQ() *conf.RocketMQ

GetRocketMQ 获取RocketMQ配置

func (*Config) Map added in v1.2.0

func (d *Config) Map() map[string]any

Map 转map

func (*Config) MarshalJSON added in v1.2.0

func (d *Config) MarshalJSON() ([]byte, error)

MarshalJSON 实现 json.Marshaler 接口

func (*Config) Scan added in v1.2.0

func (d *Config) Scan(src any) (err error)

Scan 实现 sql.Scanner 接口

func (*Config) String added in v1.2.0

func (d *Config) String() string

String 转json字符串

func (*Config) Value added in v1.2.0

func (d *Config) Value() (driver.Value, error)

Value 实现 driver.Valuer 接口

type Datasource

type Datasource interface {
	Metric() (MetricDatasource, error)
}

Datasource 数据源通用接口

func NewDatasource

func NewDatasource(config *api.DatasourceItem) Datasource

NewDatasource 根据配置创建对应的数据源

type EvalFunc

type EvalFunc func(ctx context.Context, expr string, duration *types.Duration) (map[watch.Indexer]*Point, error)

EvalFunc 指标评估函数

func MetricEval

func MetricEval(items ...MetricDatasource) EvalFunc

MetricEval 指标评估函数

type Metadata

type Metadata struct {
	// Metric 元数据列表
	Metric []*Metric `json:"metric"`
	// Timestamp 查询时间戳
	Timestamp int64 `json:"timestamp"`
}

Metadata 查询到的元数据详情

type Metric

type Metric struct {
	// Name 指标名称
	Name string `json:"name"`
	// Help 帮助信息
	Help string `json:"help"`
	// Type 类型
	Type string `json:"type"`
	// Labels 标签集合
	Labels map[string][]string `json:"labels"`
	// Unit 指标单位
	Unit string `json:"unit"`
}

Metric 查询到的数据详情, 用与元数据构建

type MetricDatasource

type MetricDatasource interface {
	Step() uint32
	// Query 查询数据
	Query(ctx context.Context, expr string, duration int64) ([]*QueryResponse, error)
	// QueryRange 查询数据
	QueryRange(ctx context.Context, expr string, start, end int64, step uint32) ([]*QueryResponse, error)
	// Metadata 查询元数据
	Metadata(ctx context.Context) (*Metadata, error)
	// GetBasicInfo 获取数据源信息
	GetBasicInfo() *BasicInfo
}

MetricDatasource 数据源完整接口定义

func NewMetricDatasource

func NewMetricDatasource(storageType vobj.StorageType, opts ...MetricDatasourceBuildOption) (MetricDatasource, error)

NewMetricDatasource 创建数据源

func NewMockMetricDatasource

func NewMockMetricDatasource() MetricDatasource

NewMockMetricDatasource 创建一个mock metric数据源

func NewPrometheusDatasource

func NewPrometheusDatasource(opts ...PrometheusOption) MetricDatasource

NewPrometheusDatasource 创建 prometheus 数据源

func NewVictoriametricsDatasource

func NewVictoriametricsDatasource(opts ...VictoriametricsDatasourceOption) MetricDatasource

NewVictoriametricsDatasource creates a new victoriametrics datasource.

type MetricDatasourceBuildOption

type MetricDatasourceBuildOption func(p *datasourceBuild)

MetricDatasourceBuildOption 数据源构建选项

func WithMetricBasicAuth

func WithMetricBasicAuth(username, password string) MetricDatasourceBuildOption

WithMetricBasicAuth 设置数据源认证信息

func WithMetricEndpoint

func WithMetricEndpoint(endpoint string) MetricDatasourceBuildOption

WithMetricEndpoint 设置数据源地址

func WithMetricID added in v1.0.2

func WithMetricID(id uint32) MetricDatasourceBuildOption

WithMetricID 设置数据源ID

func WithMetricStep

func WithMetricStep(step uint32) MetricDatasourceBuildOption

WithMetricStep 设置数据源步长

type PingDetail added in v1.1.0

type PingDetail struct {
	// 总包数
	TotalPackets float64 `json:"totalPackets,omitempty"`
	// 成功包数
	SuccessPackets float64 `json:"successPackets,omitempty"`
	// 丢包率
	LossRate float64 `json:"lossRate,omitempty"`
	// 最小延迟
	MinDelay float64 `json:"minDelay,omitempty"`
	// 最大延迟
	MaxDelay float64 `json:"maxDelay,omitempty"`
	// 平均延迟
	AvgDelay float64 `json:"avgDelay,omitempty"`
	// 标准差
	StdDevDelay float64 `json:"stdDevDelay,omitempty"`
}

PingDetail ping探测器详情

type Point

type Point struct {
	// 标签集合
	Labels map[string]string `json:"labels"`
	// 值
	Values []*Value `json:"value"`
}

Point 数据点

type PromMetadataResponse

type PromMetadataResponse struct {
	Status string                      `json:"status"`
	Data   map[string][]PromMetricInfo `json:"data"`
}

PromMetadataResponse 元数据响应

type PromMetricInfo

type PromMetricInfo struct {
	Type string `json:"type"`
	Help string `json:"help"`
	Unit string `json:"unit"`
}

PromMetricInfo 元数据信息

type PromMetricSeriesResponse

type PromMetricSeriesResponse struct {
	Status    string              `json:"status"`
	Data      []map[string]string `json:"data"`
	Error     string              `json:"error"`
	ErrorType string              `json:"errorType"`
}

PromMetricSeriesResponse 元数据响应

type PromQueryData

type PromQueryData struct {
	ResultType string             `json:"resultType"`
	Result     []*PromQueryResult `json:"result"`
}

PromQueryData 查询数据

type PromQueryResponse

type PromQueryResponse struct {
	Status    string         `json:"status"`
	Data      *PromQueryData `json:"data"`
	ErrorType string         `json:"errorType"`
	Error     string         `json:"error"`
}

PromQueryResponse 查询响应 {"status":"success","data":{"resultType":"vector","result":[{"metric":{"__name__":"node_cpu_seconds_total","cpu":"0","instance":"10.0.0.1:9100","job":"node-exporter","mode":"idle"},"value":[1629874800.0,"0.01"]},{"metric":{"__name__":"node_cpu_seconds_total","cpu":"0","instance":"10.0.0.2:9100","job":"node-exporter","mode":"idle"},"value":[1629874800.0,"0.01"]}]}}

type PromQueryResult

type PromQueryResult struct {
	Metric map[string]string `json:"metric"`
	Value  [2]any            `json:"value"`
	Values [][2]any          `json:"values"`
}

PromQueryResult 查询响应数据

type PrometheusOption

type PrometheusOption func(p *prometheusDatasource)

PrometheusOption 数据源配置

func WithPrometheusBasicAuth

func WithPrometheusBasicAuth(username, password string) PrometheusOption

WithPrometheusBasicAuth 设置数据源配置

func WithPrometheusEndpoint

func WithPrometheusEndpoint(endpoint string) PrometheusOption

WithPrometheusEndpoint 设置数据源地址

func WithPrometheusID added in v1.1.0

func WithPrometheusID(id uint32) PrometheusOption

WithPrometheusID 设置数据源ID

func WithPrometheusStep

func WithPrometheusStep(step uint32) PrometheusOption

WithPrometheusStep 设置步长

type QueryResponse

type QueryResponse struct {
	// 标签集合
	Labels map[string]string `json:"labels"`
	// 值
	Value  *QueryValue   `json:"value"`
	Values []*QueryValue `json:"values"`
	// 结果类型
	ResultType string `json:"resultType"`
}

QueryResponse 查询到的响应

type QueryValue

type QueryValue struct {
	Value     float64 `json:"value"`
	Timestamp int64   `json:"timestamp"`
}

QueryValue 查询到的值

type Value

type Value struct {
	Value     float64 `json:"value"`
	Timestamp int64   `json:"timestamp"`
}

Value 数据源查询值

type VictoriametricsDatasourceOption

type VictoriametricsDatasourceOption func(*victoriametricsDatasource)

VictoriametricsDatasourceOption victoriametrics数据源选项

func WithVictoriametricsBasicAuth

func WithVictoriametricsBasicAuth(username, password string) VictoriametricsDatasourceOption

WithVictoriametricsBasicAuth 设置数据源配置

func WithVictoriametricsEndpoint

func WithVictoriametricsEndpoint(endpoint string) VictoriametricsDatasourceOption

WithVictoriametricsEndpoint 设置数据源地址

func WithVictoriametricsID added in v1.1.0

func WithVictoriametricsID(id uint32) VictoriametricsDatasourceOption

WithVictoriametricsID 设置数据源ID

func WithVictoriametricsStep

func WithVictoriametricsStep(step uint32) VictoriametricsDatasourceOption

WithVictoriametricsStep 设置步长

type VictoriametricsMetadataResponse

type VictoriametricsMetadataResponse struct {
	Status string   `json:"status"`
	Data   []string `json:"data"`
}

VictoriametricsMetadataResponse victoriametrics元数据响应

Jump to

Keyboard shortcuts

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