Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/dingjs/javaagent
基于javaagent开发的APM工具,收集方法的执行次数和执行时间,定时输出成json格式的日志。
https://github.com/dingjs/javaagent
Last synced: 3 months ago
JSON representation
基于javaagent开发的APM工具,收集方法的执行次数和执行时间,定时输出成json格式的日志。
- Host: GitHub
- URL: https://github.com/dingjs/javaagent
- Owner: dingjs
- License: apache-2.0
- Created: 2015-09-17T13:21:03.000Z (almost 9 years ago)
- Default Branch: master
- Last Pushed: 2023-10-16T10:04:06.000Z (8 months ago)
- Last Synced: 2024-01-16T10:12:12.615Z (5 months ago)
- Language: Java
- Homepage:
- Size: 712 KB
- Stars: 367
- Watchers: 29
- Forks: 157
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Lists
- awesome - javaagent - 基于javaagent开发的APM工具,收集方法的执行次数和执行时间,定时输出成json格式的日志。 (Java)
README
# 🎉 Javaagent 🎉
## 概述
**javaagent** 是一个简单优雅的 java agent ,利用 java 自带的 `instrument` 特性+ `javassist` 字节码编辑技术,实现了无侵入的方法级性能监控。相比于NewRelic或者开源的[pinpoint](https://github.com/naver/pinpoint),以及阿里的[arthas](https://github.com/alibaba/arthas),本工具主打的是简单,我们只记录每个方法的执行次数和时间,并输出到json格式的日志文件中。基于javaagent的日志,你可以使用严丽同学开发的[agent日志分析工具](https://pan.baidu.com/s/1Ma4iEWRmBonGO1TapeEF-g)进行分析查询,或者可以自己去写分析器,这样可以让你快速定位生产环境的性能瓶颈。## 集成
java启动参数中就有javaagent,你只需要在JAVA_OPTS中加入`-javaagent:/opt/javaagent/javaagent.jar=/opt/javaagent/agent.properties`就实现了方法级监控。其中`=`前指定的是jar包的路径,`=`后指定的是对agent的一些配置参数。### agent.properties说明
```
# 需要监控的包,多个包用分号分隔
agent.include.package=com.XXX
# 不需要监控的包,多个包用分号分隔。 需要监控的包-不需要监控的包就是真正要监控的包
agent.exclude.package=
# 日志文件,会自动增加日期后缀
agent.log.file=/opt/agent.log
# 日志输出周期
agent.log.interval.seconds=600
# 不需要监控的类的正则表达式
agent.exclude.class.regex=
# 是否记录平均时间
agent.log.avg.execute.time=false
# 记录方法的耗时时是采用nanoTime,还是currentTimeMillis,nanoTime更准确,但是会耗时一些
agent.log.nano=true
```## agent日志分析器使用
agent日志分析器是我同事严丽使用SpringBoot+h2数据库开发的分析工具,除了基础功能,对于有sql能力的同学,你可以直接使用[agent日志分析工具](https://pan.baidu.com/s/1Ma4iEWRmBonGO1TapeEF-g)自带的[console](http://ip:port/console)登录后,直接写sql进行统计,你可以按自己想要的维度来进行处理。
- JDBC URL: jdbc:h2:mem:~/h2test
- USer Name : sa
- Password : 空登录后,你就可以尽情地写 sql 对类、方法的执行次数、执行时间进行统计查询。
## 欢迎关注我的公众号
- 程序员阿水![程序员阿水](https://user-images.githubusercontent.com/3361218/116490540-3ae6da80-a8ca-11eb-97b9-5b9f41dc7740.jpg)