Agent 的使用-Spring Boot | 学习笔记

简介: 快速学习 Agent 的使用-Spring Boot

开发者学堂课程【分布式链路追踪 SkywalkingAgent 的使用-Spring Boot】学习笔记,与课程紧密连接,让用户快速学习知识。

课程地址https://developer.aliyun.com/learning/course/743/detail/13157


Agent 的使用-Spring Boot


内容介绍:

一、Window 下 Tomcat7和8中使用 Agent

二、Spring Boot 中使用 Agent


一、Window 下 Tomcat7和8中使用 Agent

在 window 中使用 Agent 和在 Linux 下使用的方式类似,但是需要修改的文件从原来的 catalina.sh 变成了 catalina.bat,因为 bat 是在 window下 使用的,所以需要将第一行修改为 bat 能识别的一串代码:set "CATALINA_OPTS=-javaagent:/path/to/skywalking-agent/skywalking-agent.jar",在 set "CATALINA_OPTS 后加上 javaagent 的使用方式,用 -javaagent 指向 javaagent 的目录以及它的架包。也就是说,skywalking 在 window 下的使用和在 Linux 下使用的方式其实是一样的。,只不过在语法方面需要修改为 bat。


二、Spring Boot 中使用 Agent

1. Skywalking 与Spring Boot 集成

下面学习 Skywalking 如何与Spring Boot 做集成,来监控 Spring Boot 中接口的调用

(1)处理工作

如图:

image.png

现在处于一个 agent 的目录下,而这个目录当前实际上是被 Tomcat 使用的。

将 agent 拷贝一份,如图:

image.png

image.png

将其改为 agent_boot,然后进入 agent_boot 这个目录下。

这里需要修改的依旧是 config 目录,如图:

image.png

进入 config 目录,找到配置文件进行修改,如图:

image.png

image.png

将 agent.service_name 这句话的服务名改为 skywalking_boot,这样用于做一个服务的区别,即可以分出到底是 Tomcat 发布还是 spring_boot 发布的。此时,在 agentboot 下已经修改完配置文件,也就是说现在有两个 agent 可以使用,一个是 Tomcat 进行使用的,一个是 spring_boot 使用的。这样的方式看似很麻烦,但是设想如果将来应用上线,一般情况下一个虚拟仪只会放一个应用,为了避免过多的应用产生资源的争抢,这个时候就可以在虚拟仪上只放置一份 agent 。不过如果只是演示,就需要在一台虚拟机上启用多个应用,因此会认为这种方式麻烦。这个问题也可以用插件的方式解决。

(2)上传应用

将 skywalking_springboot 应用上传到虚拟机中,同时启动。

以下是 springboot 的一部分代码:

<parent>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-starter-parent</artifactId>

<version>2.1.10.RELEASE</version>

<relativePath/><!--Lookup parent from repository-->

</parent>

<groupId>com.itcast</groupId>

<artifactId>skywalking_springboot<artifactId>

<dependencies>

<dependency>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-starter-web</artifactId>

在 pom 中,已经引入了 springboot 相关的依赖,这个依赖使用的版本号是2.1.10 ,而且使用了 spring-boot-starer-web 进行 springmvc 的一个集成。

还提供了一个 controller,

如以下代码:

RestController

public class MyController{

//正常访问接口

@RequestMapping("/sayBoot")

public String sayBoot() {return "Hello Boot!"; }

//异常访问接口

@RequestMapping("/exception")

public String exception(){

int i =1/0;

return  "Hello Boot!";

这个 controller 有两个接口,一个叫 sayboot,它是一个正常访问的接口;一个叫 exception,是一个异常访问的接口,这个接口是通过1/0的方式来抛出一个除0异常。

如图,把 springboot 工程上传到虚拟机中:

image.png

使用工具进行上传,上传后即可通过启动 springboot 来进行验证。

(3)启动 Springboot

在启动前需要注意,正常启动前的应用不会和 skywalking 做集成,所以需要通过启动命令中添加探针的方式来进行启动,这个方式和之前使用 Tomcat 的方式是类似的

如下代码:

java -javaagentl/usr/local/skywalking/apache-skywalking-apm-bin/agent_boot/skywalking-agent.jar -Dserver.port=8082 -jarskywalking_springboot.jar  &

在命令中加上 -javaagent 参数来指定 javaagent 的一个位置。

如图:

image.png

进行启动,首先把目录切换到 usr/local/skywalking 下,

如图:

image.png

可以看到,Springboot 已经上传成功。

在这个目录下,可以通过 java 加上参数 javaagent 来启动,

image.png

此时如果拷贝错误,需要手动输入,然后找到 skywalking.jar ,在加上参数之后指定启动的端口,也就是 Dserver.port=8082,然后再通过 /jar 命令找到架包并且用&进行后端的启动。

image.png

此时虽然在控制端还是打出了启动执行命令,但是它并不是在前端进行启动而是通过后台进行启动,所以即便把控制台进行退出也不会影响到系统运行。此时,应用启动成功。

image.png

(4)访问

如图:

image.png

在浏览器进行应用的访问。将端口改为8082,应用名不需要加,

然后看到它的一个接口 sayboot,来进行验证。

image.png

如果返回了 helloboot,就说明是一个正常访问。

image.png

然后再访问后面的异常接口,如图:

image.png

如图,这里前端报错,报的是/ by zero,也就是除0错误,抛出一个除0异常同时标记成500,这说明这是一个异常访问。

image.png

(5)查看 skywalking 信息

在 skywalking 中查看是否有上述记录,如图:

image.png

如图,这里有两条访问记录,在 skywalking_boot 下的依次是 exception 和 sayboot这两个接口。

然后在追踪中详细查看信息,

如图,exception 已经标红,证明它是一次失败的调用,它的持续时间是359毫秒。而 sayboot 是一次正常的调用,所以是蓝色的,持续时间是296毫秒。

image.png

image.png

在服务上找到 springboot 的服务,同时它的实例在141上,进程 ID 是10986,证明这个应用和这个实例已经被我们监控起来了。

image.png

如图,查看拓扑图:

image.png

可以看到,现在 User 一方面调用了skywalking_boot,一方面又调用了 sky walking_tomcat,而这两个本质上都是 springmvc 的项目,springboot 实际上是通过 web 端进行访问,也是基于 mvc 。至此,springboot 已经和 skywalking 完成了集成。

其实启动的方式大致相同,只是 springboot 的启动需要在 java 后 加上 javaagent 这个参数来指定一个 agent 探针。

相关文章
|
6月前
|
监控 Java 应用服务中间件
微服务——SpringBoot使用归纳——为什么学习Spring Boot
本文主要探讨为什么学习Spring Boot。从Spring官方定位来看,Spring Boot旨在快速启动和运行项目,简化配置与编码。其优点包括:1) 良好的基因,继承了Spring框架的优点;2) 简化编码,通过starter依赖减少手动配置;3) 简化配置,采用Java Config方式替代繁琐的XML配置;4) 简化部署,内嵌Tomcat支持一键式启动;5) 简化监控,提供运行期性能参数获取功能。此外,从未来发展趋势看,微服务架构逐渐成为主流,而Spring Boot作为官方推荐技术,与Spring Cloud配合使用,将成为未来发展的重要方向。
191 0
微服务——SpringBoot使用归纳——为什么学习Spring Boot
|
5月前
|
Java Spring
Spring框架的学习与应用
总的来说,Spring框架是Java开发中的一把强大的工具。通过理解其核心概念,通过实践来学习和掌握,你可以充分利用Spring框架的强大功能,提高你的开发效率和代码质量。
141 20
|
8月前
|
XML Java 应用服务中间件
Spring Boot 两种部署到服务器的方式
本文介绍了Spring Boot项目的两种部署方式:jar包和war包。Jar包方式使用内置Tomcat,只需配置JDK 1.8及以上环境,通过`nohup java -jar`命令后台运行,并开放服务器端口即可访问。War包则需将项目打包后放入外部Tomcat的webapps目录,修改启动类继承`SpringBootServletInitializer`并调整pom.xml中的打包类型为war,最后启动Tomcat访问应用。两者各有优劣,jar包更简单便捷,而war包适合传统部署场景。需要注意的是,war包部署时,内置Tomcat的端口配置不会生效。
2109 17
Spring Boot 两种部署到服务器的方式
|
6月前
|
Java 数据库 微服务
微服务——SpringBoot使用归纳——Spring Boot中的项目属性配置——指定项目配置文件
在实际项目中,开发环境和生产环境的配置往往不同。为简化配置切换,可通过创建 `application-dev.yml` 和 `application-pro.yml` 分别管理开发与生产环境配置,如设置不同端口(8001/8002)。在 `application.yml` 中使用 `spring.profiles.active` 指定加载的配置文件,实现环境快速切换。本节还介绍了通过配置类读取参数的方法,适用于微服务场景,提升代码可维护性。课程源码可从 [Gitee](https://gitee.com/eson15/springboot_study) 下载。
214 0
|
10月前
|
前端开发 Java 开发者
Spring生态学习路径与源码深度探讨
【11月更文挑战第13天】Spring框架作为Java企业级开发中的核心框架,其丰富的生态系统和强大的功能吸引了无数开发者的关注。学习Spring生态不仅仅是掌握Spring Framework本身,更需要深入理解其周边组件和工具,以及源码的底层实现逻辑。本文将从Spring生态的学习路径入手,详细探讨如何系统地学习Spring,并深入解析各个重点的底层实现逻辑。
210 9
|
10月前
|
存储 运维 安全
Spring运维之boot项目多环境(yaml 多文件 proerties)及分组管理与开发控制
通过以上措施,可以保证Spring Boot项目的配置管理在专业水准上,并且易于维护和管理,符合搜索引擎收录标准。
476 2
|
11月前
|
前端开发 Java 数据库
SpringBoot学习
【10月更文挑战第7天】Spring学习
121 9
|
11月前
|
XML Java 数据格式
Spring学习
【10月更文挑战第6天】Spring学习
79 1
|
11月前
|
Java 测试技术 开发者
springboot学习四:Spring Boot profile多环境配置、devtools热部署
这篇文章主要介绍了如何在Spring Boot中进行多环境配置以及如何整合DevTools实现热部署,以提高开发效率。
438 2
|
11月前
|
前端开发 Java 程序员
springboot 学习十五:Spring Boot 优雅的集成Swagger2、Knife4j
这篇文章是关于如何在Spring Boot项目中集成Swagger2和Knife4j来生成和美化API接口文档的详细教程。
1690 1

热门文章

最新文章