tidb data 源码

  • 2022-09-19
  • 浏览 (441)

tidb data 代码

文件路径:/telemetry/data.go

// Copyright 2020 PingCAP, Inc.
//
// 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 telemetry

import (
	"context"
	"time"

	"github.com/pingcap/tidb/kv"
	"github.com/pingcap/tidb/sessionctx"
)

type telemetryData struct {
	Hardware           []*clusterHardwareItem  `json:"hardware"`
	Instances          []*clusterInfoItem      `json:"instances"`
	TelemetryHostExtra *telemetryHostExtraInfo `json:"hostExtra"`
	ReportTimestamp    int64                   `json:"reportTimestamp"`
	TrackingID         string                  `json:"trackingId"`
	FeatureUsage       *featureUsage           `json:"featureUsage"`
	WindowedStats      []*windowData           `json:"windowedStats"`
	SlowQueryStats     *slowQueryStats         `json:"slowQueryStats"`
}

func generateTelemetryData(sctx sessionctx.Context, trackingID string) telemetryData {
	ctx := kv.WithInternalSourceType(context.Background(), kv.InternalTxnTelemetry)
	r := telemetryData{
		ReportTimestamp: time.Now().Unix(),
		TrackingID:      trackingID,
	}
	if h, err := getClusterHardware(ctx, sctx); err == nil {
		r.Hardware = h
	}
	if i, err := getClusterInfo(ctx, sctx); err == nil {
		r.Instances = i
	}
	if f, err := getFeatureUsage(ctx, sctx); err == nil {
		r.FeatureUsage = f
	}
	if s, err := getSlowQueryStats(); err == nil {
		r.SlowQueryStats = s
	}

	r.WindowedStats = getWindowData()
	r.TelemetryHostExtra = getTelemetryHostExtraInfo()
	return r
}

func postReportTelemetryData() {
	postReportTxnUsage()
	postReportCTEUsage()
	postReportAccountLockUsage()
	postReportMultiSchemaChangeUsage()
	postReportTablePartitionUsage()
	postReportSlowQueryStats()
	postReportNonTransactionalCounter()
	PostSavepointCount()
	postReportLazyPessimisticUniqueCheckSetCount()
}

// PostReportTelemetryDataForTest is for test.
func PostReportTelemetryDataForTest() {
	postReportTablePartitionUsage()
}

相关信息

tidb 源码目录

相关文章

tidb data_cluster_hardware 源码

tidb data_cluster_info 源码

tidb data_feature_usage 源码

tidb data_slow_query 源码

tidb data_telemetry_host_extra 源码

tidb data_window 源码

tidb id 源码

tidb status 源码

tidb telemetry 源码

tidb util 源码

0  赞