boot分布式计算 spring_在spring boot中三分钟上手apache顶级分布式链路追踪系统skywalking...

skywalking在apache里全票通过成为了apache顶级链路追踪系统

虽然官方文档很全,但是中文文档目前还没完全翻译过来,研究文档需要花费一些时间,下面作者整理总结了官方文档,可以帮助读者快速上手

skywalking拥有丰富的三方库追踪支持,参考: apm-sdk-plugin

常用的组件比如dubbo, httpclient, rocketmq, jdbc, hystrix等都已官方支持了

为了快速启动项目,会使用docker技术

下载编译

git clone https://github.com/apache/skywalking.git

git submodule init

git submodule update

复制代码

执行编译

mvn clean package -Dmaven.test.skip=true

复制代码

首次编译需要下载依赖,等待的时间可能会久一些

出现下面的提示就是编译成功了

查看dist目录里的编译结果

可以看到skywalking的部署包成功生成了

构建skywalking运行的docker镜像

docker时区修改为 Asia/Shanghai

进入docker目录,编辑docker-compose.yml,为elasticsearch, oap, ui服务添加时区环境变量为 Asia/Shanghai

核心代码如下

environment:

TZ: Asia/Shanghai

复制代码

完整的docker-compose.yml已上传github,参考:docker-compose.yml

构建docker镜像

执行命令 make build 开始构建docker镜像

使用docker images命令查看构建的容器

可以看到skywalking部署需要的ui和oap服务已经构建成功了

启动skywalking服务

使用命令docker-compose up -d启动服务

在浏览器里打开 ip:8080 查看效果

使用默认的用户名和密码 admin admin登陆管理后台

编写测试代码

可以使用现成的spring boot项目,也可以在 start.spring.io/ 创建一个新的spring boot项目

下面编写几个请求来试用下skywalking的追踪功能

核心案例代码如下

普通请求

@RequestMapping("test1")

public String test1(){

return "Hello World";

}

复制代码

异常请求

@RequestMapping("test2")

public String test2(){

if (true) {

throw new RuntimeException("a exception occured");

}

return "Hello World2";

}

复制代码

超时请求

@RequestMapping("test3")

public String test3() throws InterruptedException{

Thread.sleep(10000);

return "Hello World3";

}

复制代码

将项目打成jar,带上skywalking启动

把skywalking项目目录里的skywalking-agent复制一份到项目里

然后修改skywalking-agent/config/agent.config配置文件

主要是修改上图里的项目名称,这样在控制后台就好标识出这个项目了,比如把配置 agent.service_name修改成myskywalking

启动spring boot项目

mvn clean package -Dmaven.test.skip=true

java -javaagent:项目所在目录/skywalking-agent/skywalking-agent.jar -jar target/myskywalking-0.0.1-SNAPSHOT.jar

复制代码

然后在浏览器里请求上面编写的测试代码,可以使用curl,比如:

curl -k -vvv http://127.0.0.1:8080/test/test1

curl -k -vvv http://127.0.0.1:8080/test/test2

curl -k -vvv http://127.0.0.1:8080/test/test3

复制代码

然后在skywalking管理后台查看追踪到的数据

在追踪页面可以看到请求

默认skywalking会抓取100%的请求,可以修改agent.config配置文件中的agent.sample_n_per_3_secs配置项配置抓取的请求的百分比

查看异常的请求

可以看到异常请求调用的堆栈信息被记录,这个在排查问题的过程中一般都会用到

一些注意的点

如果使用的组建没有内置的追踪支持,可以自行编写插件实现,插件编写参考:Java-Plugin-Development-Guide.md

docker容器里的时区要设置成和浏览器所在的机器的时区一致,比如 Aisa/Shanghai,不一致可能无法在浏览器里查看追踪的数据

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值