阿里云-spring boot 接入SLS日志

1.spring boot项目接入阿里云SLS日志

目的:收集业务日志

本项目集成:Slf4j、sls 通过配置log.xml,log.info()无侵入的更换日志采集

1.1.开通阿里云SLS日志收集

地址:

https://sls.console.aliyun.com/lognext/profile

1.2.创建project

1.3.接入数据

java应用的业务日志

1.4.项目配置

添加依赖

java 复制代码
        <!-- https://mvnrepository.com/artifact/com.aliyun.openservices/aliyun-log-logback-appender -->
        <dependency>
            <groupId>com.aliyun.openservices</groupId>
            <artifactId>aliyun-log-logback-appender</artifactId>
            <version>0.1.18</version>
        </dependency>

        <!-- https://mvnrepository.com/artifact/com.alibaba.arms.apm/arms-sdk -->
        <dependency>
            <groupId>com.alibaba.arms.apm</groupId>
            <artifactId>arms-sdk</artifactId>
            <version>1.7.5</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/cn.hutool/hutool-core -->
        <dependency>
            <groupId>cn.hutool</groupId>
            <artifactId>hutool-core</artifactId>
            <version>5.8.38</version>
        </dependency>

        <!-- https://mvnrepository.com/artifact/org.apache.commons/commons-lang3 -->
        <dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-lang3</artifactId>
            <version>3.17.0</version>
        </dependency>

配置日志(直接把日志写入到SLS)

java 复制代码
<?xml version="1.0" encoding="UTF-8"?>
<configuration scan="true" scanPeriod="60 seconds" debug="false">
    <timestamp key="bySecond" datePattern="yyyyMMdd'T'HHmmss"/>

    <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
            <pattern>%red(%d{yyyy-MM-dd HH:mm:ss}) %green([%thread]) [%X{traceId}] %highlight(%-5level) %boldMagenta(%logger{10}) - %cyan(%msg%n)</pattern>
        </encoder>
    </appender>

    <appender name="aliyun" class="com.aliyun.openservices.log.logback.LoghubAppender">
        <endpoint>cn-hangzhou.log.aliyuncs.com</endpoint>
        <accessKeyId>LTAI*********hAD7a</accessKeyId>           // 密钥管理申请
        <accessKeySecret>y*************ETp</accessKeySecret>
        <project>arms-sls-test</project>
        <logStore>arms-sls-logstore</logStore>
        <topic>arms-sls-topic</topic>

        <!-- Optional parameters -->
        <totalSizeInBytes>104857600</totalSizeInBytes>
        <maxBlockMs>0</maxBlockMs>
        <ioThreadCount>8</ioThreadCount>
        <batchSizeThresholdInBytes>524288</batchSizeThresholdInBytes>
        <batchCountThreshold>4096</batchCountThreshold>
        <lingerMs>2000</lingerMs>
        <retries>10</retries>
        <baseRetryBackoffMs>100</baseRetryBackoffMs>
        <maxRetryBackoffMs>50000</maxRetryBackoffMs>
        <timeFormat>yyyy-MM-dd'T'HH:mmZ</timeFormat>
        <timeZone>Asia/Shanghai</timeZone>

        <mdcFields>traceId</mdcFields>
    </appender>

    <root level="INFO">
        <appender-ref ref="STDOUT"/>
        <appender-ref ref="aliyun"/>
    </root>
</configuration>

获取traceId

java 复制代码
package org.draymond.arms.utils;

import jakarta.servlet.http.HttpServletRequest;

import cn.hutool.core.lang.UUID;
import com.alibaba.arms.tracing.Span;
import com.alibaba.arms.tracing.Tracer;
import org.apache.commons.lang3.StringUtils;
public class TraceIdUtil {

    public static String getTraceIdHttpRequest(HttpServletRequest request) {
        Span span = Tracer.builder().getSpan();
        String traceId = span.getTraceId();
        if (StringUtils.isNotBlank(traceId)) {
            return traceId;
        } else {
            traceId = StringUtils.isBlank(request.getHeader("trace_id")) ? request.getHeader("traceId") : request.getHeader("trace_id");
            return StringUtils.isNotBlank(traceId) ? traceId : UUID.fastUUID().toString();
        }
    }

    public static String getTraceId() {
        Span span = Tracer.builder().getSpan();
        String traceId = span.getTraceId();
        return StringUtils.isNotBlank(traceId) ? traceId : UUID.fastUUID().toString();
    }
}

业务使用

java 复制代码
@Slf4j
@Component
public class ArmsService {


    /**
     * 测试cpu占用
     *
     * @param number
     * @return
     */
    public ArmsModel cpuTest(Integer number) {
        MDC.put("traceId", TraceIdUtil.getTraceId());
        log.info("cpu测试, number={}", number);
        sleepNumberTime(number);
        ArmsModel build = ArmsModel.build(number);
        return build;
    }

}

SLS效果

后续可以根据traceId查询分布式日志

arms中使用traceId查询调用链

全链路

相关推荐
翼龙云_cloud17 小时前
阿里云云渠道商:如何选择阿里云 GPU 配置方案?
服务器·人工智能·阿里云·云计算
diudiu96281 天前
Maven配置阿里云镜像
java·spring·阿里云·servlet·eclipse·tomcat·maven
咕噜企业分发小米2 天前
阿里云基因测序数据分析平台有哪些成功案例?
阿里云·数据分析·云计算
咕噜企业分发小米2 天前
阿里云与华为云在基因测序数据存储上哪个更好?
服务器·阿里云·腾讯云
翼龙云_cloud2 天前
阿里云渠道商:阿里云GPU怎么搭建部署个人作品集博客?
运维·服务器·阿里云·云计算
啦啦啦~~~7542 天前
【最新版】Edge浏览器安装!绿色增强版+禁止Edge更新的软件+彻底卸载Edge软件
数据库·阿里云·电脑·.net·edge浏览器
咕噜企业分发小米2 天前
阿里云与华为云在基因测序数据分析上哪个更强?
阿里云·数据分析·华为云
阿里云云原生2 天前
Android App 崩溃排查实战:如何利用 RUM 完整数据与符号化技术定位问题?
android·阿里云·云原生·rum
阿里云云原生2 天前
深度解析云监控 2.0 日志审计:统一采集、实体建模与告警溯源能力
阿里云·云原生·云监控·可观测
驱动探索者3 天前
[缩略语大全]之[数据中心]篇
arm开发·阿里云