Skywalking为数据库添加多维度数据

本文介绍如何在Skywalking 8.3版本中针对elasticsearch6.x存储,添加自定义数据源并实现带搜索条件的查询接口。通过扩充数据库存储慢SQL信息,并在查询接口上增加服务名、接口名和实例的搜索条件,以增强仪表盘的数据检索能力。主要涉及修改契约、服务实现以及前端接口调整。
摘要由CSDN通过智能技术生成

目录

前提声明:

1、扩充数据源并存储进es中

2、查询接口改造成带搜索条件的


前提声明:

版本:8.3版本  基于elasticsearch6.x存储

需求:希望仪表盘数据中的database中的慢sql能够根据服务名,接口名和实例来检索出慢sql数据,大致如下图所示。

那么其实是要求我们做两件事:
1、扩充数据源并存储进es中

2、查询接口改造成带搜索条件的

1、扩充数据源并存储进es中

DatabaseSlowStatement实体添加额外字段
package org.apache.skywalking.oap.server.core.source;

import lombok.Getter;
import lombok.Setter;
import org.apache.skywalking.oap.server.core.Const;

import static org.apache.skywalking.oap.server.core.source.DefaultScopeDefine.DATABASE_SLOW_STATEMENT;

@ScopeDeclaration(id = DATABASE_SLOW_STATEMENT, name = "DatabaseSlowStatement")
public class DatabaseSlowStatement extends Source {
    @Getter
    @Setter
    private String id;
    @Getter
    @Setter
    private String databaseServiceId;
    @Getter
    @Setter
    private String statement;
    @Getter
    @Setter
    private long latency;
    @Getter
    @Setter
    private String traceId;
    // 为慢sql添加更多维度数据
    @Getter
    @Setter
    private String sourceServiceName;
    @Getter
    @Setter
    private String sourceServiceInstanceName;
    @Getter
    @Setter
    private String operationName;



    @Override
    public int scope() {
        return DefaultScopeDefine.DATABASE_SLOW_STATEMENT;
    }

    @Override
    public String getEntityId() {
        return Const.EMPTY_STRING;
    }

}
MultiScopesAnalysisListener#parseExit(SpanObject span, SegmentObject segmentObject)添加赋值逻辑
/**
 * The exit span should be transferred to the service, instance and relationships from the client side detect
 * point.
 */
@Override
public void parseExit(SpanObject span, SegmentObject segmentObject) {
    if (span.getSkipAnalysis()) {
        return;
    }

    SourceBuilder sourceBuilder = new SourceBuilder(namingControl);

    final String networkAddress = span.getPeer();
    if (StringUtil.isEmpty(networkAddress)) {
        return;
    }

    sourceBuilder.setSourceServiceName(segmentObject.getService());
    sourceBuilder.setSourceNodeType(NodeType.Normal);
    sourceBuilder.setSourceServiceInstanceName(segmentObject.getServiceInstance());

    final NetworkAddressAlias networkAddressAlias = networkAddressAliasCache.get(networkAddress);
    if (networkAddressAlias == null) {
        sourceBuilder.setDestServiceName(networkAddress);
        sourceBuilder.setDestServiceInstanceName(networkAddress);
        sourceBuilder.setDestNodeType(NodeType.fromSpanLayerValue(span.getSpanLayer()));
    } else {
        /*
         * If alias exists, mean this network address is representing a real service.
         */
        final IDManager.ServiceID.ServiceIDDefinition serviceIDDefinition = IDManager.ServiceID.analysisId(
            networkAddressAlias.getRepresentServiceId());
        final IDManager.ServiceInstanceID.InstanceIDDefinition instanceIDDefinition = IDManager.ServiceInstanceID
            .analysisId(
                networkAddressAlias.getRepresentServiceInstanceId());
        sourceBuilder.setDestServiceName(serviceIDDefinition.getName());
        /*
         * Some of the agent can not have the upstream real network address, such as https://github.com/apache/skywalking-nginx-lua.
         * Keeping dest instance name as NULL makes no instance relation generate from this exit span.
         */
        if (!config.shouldIgnorePeerIPDue2Virtual(span.getComponentId())) {
            sourceBuilder.setDestServiceInstanceName(instanceIDDefinition.getName());
        }
        sourceBuilder.setDestNodeType(NodeType.Normal);
    }

    sourceBuilder.setDetectPoint(DetectPoint.CLIENT);
    sourceBuilder.setComponentId(span.getComponentId());
    setPublicAttrs(sourceBuilder, span);
    exitSourceBuilders.add(sourceBuilder);

    if (sourceBuilder.getType().equals(RequestType.DATABASE)) {
        boolean isSlowDBAccess = false;

        DatabaseSlowStatement statement = new DatabaseSlowStatement();
        statement.setId(segmentObject.getTraceSegmentId() + "-" + span.getSpanId());
        statement.setDatabaseServiceId(
            IDManager.ServiceID.buildId(networkAddress, NodeType.Databa
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值