Spring Cloud 整合Apache-SkyWalking实现链路跟踪的方法

所属分类: 软件编程 / java 阅读数: 53
收藏 0 赞 0 分享

什么是SkyWalking

查看官网https://skywalking.apache.org/

分布式系统的应用程序性能监视工具,专为微服务、云原生架构和基于容器(Docker、K8s、Mesos)架构而设计。

安装

进入下载页面https://skywalking.apache.org/zh/downloads/
这里用的是ElasticSearch 7版本,所以你需要安装完成ElasticSearch 7,不再赘述。

在这里插入图片描述

解压后,可以修改启动端口


apache-skywalking-apm-bin-es7/webapp/webapp.yml

启动

bin/startup.bat
打开地址:http:.//localhost:8080

在这里插入图片描述

部署完成了,你也可以使用Docker 部署。如下:

[root@localhost ~]# docker search skywalking
NAME        DESCRIPTION 
apache/skywalking-oap-server  Apache SkyWalking OAP Server 
apache/skywalking-ui    Apache SkyWalking Web UI 

拉取

docker pull apache/skywalking-oap-server 
docker pull apache/skywalking-ui

启动容器

docker run \
--name skywalking \
 -d \
 -p 11800:11800 \
 -p 12800:12800 \
 --restart always \
 --link elasticsearch:elasticsearch \
 -e TZ=Asia/Shanghai \
 -e SW_STORAGE=elasticsearch \
 -e SW_STORAGE_ES_CLUSTER_NODES=elasticsearch:9200 \
 apache/skywalking-oap-server 

docker run \
--name skywalking-ui \
-d \
 -p 7070:8080 \
--link skywalking:skywalking \
 -e TZ=Asia/Shanghai \
-e SW_OAP_ADDRESS=skywalking:12800 \
 --restart always \
apache/skywalking-ui \

地址为 http://内网宿主机ip:7070
连接地址为:内网宿主机ip:11800

agent 镜像使用:

待补充

使用

Java Agent简介

简单说:我们可以使用agent技术构建一个独立于应用程序的代理程序(即为Agent),用来协助监测、运行甚至替换其他JVM上的程序。使用它可以实现虚拟机级别的AOP功能。

SpringBoot 使用 Java Agent

首先将安装目录下的agent目录全部拷贝到你的项目文件夹下

接着(IDEA为例),改为你的地址即可

-javaagent:D:\Project\jiangsu-unified-platform\apache-skywalking\agent\skywalking-agent.jar
-Dskywalking.agent.service_name=jiangsu-bid-service
-Dskywalking.collector.backend_service=192.168.11.137:11800

在这里插入图片描述

启动项目,日志已经出现了。

在这里插入图片描述

刷新页面,已经注册了。

在这里插入图片描述

现在点击一个请求测试下,你可以点开各个页面,查看信息了。

在这里插入图片描述

请求路径分析

在这里插入图片描述

正常,需要配合网关使用。
将插件放入,然后和之前一样配置下,修改下service的名称。

在这里插入图片描述

这里我是JDK11 启动报错

java.lang.UnsupportedOperationException: Reflective setAccessible(true) disabled
	at org.apache.skywalking.apm.dependencies.io.netty.util.internal.ReflectionUtil.trySetAccessible(ReflectionUtil.java:31)
	at org.apache.skywalking.apm.dependencies.io.netty.util.internal.PlatformDependent0$4.run(PlatformDependent0.java:224)
	at java.base/java.security.AccessController.doPrivileged(Native Method)
	...
	java.lang.IllegalAccessException: class org.apache.skywalking.apm.dependencies.io.netty.util.internal.PlatformDependent0$6 cannot access class jdk.internal.misc.Unsafe (in module java.base) because module java.base does not export jdk.internal.misc to unnamed module @74960bfa
	at java.base/jdk.internal.reflect.Reflection.newIllegalAccessException(Reflection.java:361)
	at java.base/java.lang.reflect.AccessibleObject.checkAccess(AccessibleObject.java:591)
	at java.base/java.lang.reflect.Method.invoke(Method.java:558)
	at org.apache.skywalking.apm.dependencies.io.netty.util.internal.PlatformDependent0$6.run(PlatformDependent0.java:334)
	at java.base/java.security.AccessController.doPrivileged(Native Method)

但是没影响。请求后,查看拓扑图,调用了哪些组件一目了然。

在这里插入图片描述

更多精彩内容其他人还在看

SpringBoot SpEL语法扫盲与查询手册的实现

这篇文章主要介绍了SpringBoot SpEL语法扫盲与查询手册的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
收藏 0 赞 0 分享

Java创建子线程的两种方法

这篇文章主要介绍了Java创建子线程的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
收藏 0 赞 0 分享

Spring Boot2.x集成JPA快速开发的示例代码

这篇文章主要介绍了Spring Boot2.x集成JPA快速开发,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
收藏 0 赞 0 分享

关于Java中的mysql时区问题详解

这篇文章主要给大家介绍了关于Java中mysql时区问题的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Java具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
收藏 0 赞 0 分享

JAVA参数传递方式实例浅析【按值传递与引用传递区别】

这篇文章主要介绍了JAVA参数传递方式,结合实例形式分析了java按值传递与引用传递区别及相关操作注意事项,需要的朋友可以参考下
收藏 0 赞 0 分享

Java中MessageDigest来实现数据加密的方法

这篇文章主要介绍了Java中MessageDigest来实现数据加密的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
收藏 0 赞 0 分享

spring 注解验证@NotNull等使用方法

这篇文章主要介绍了spring 注解验证@NotNull等使用方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
收藏 0 赞 0 分享

浅谈如何优雅地停止Spring Boot应用

这篇文章主要介绍了浅谈如何优雅地停止Spring Boot应用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
收藏 0 赞 0 分享

Python如何使用@property @x.setter及@x.deleter

这篇文章主要介绍了Python如何使用@property @x.setter及@x.deleter,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
收藏 0 赞 0 分享

Java Jmeter全局变量设置过程图解

这篇文章主要介绍了Java Jmeter全局变量设置过程图解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
收藏 0 赞 0 分享
查看更多