Skip to content
Bistoury是去哪儿网的java应用生产问题诊断工具,提供了一站式的问题诊断功能
Java JavaScript HTML CSS Other
Branch: master
Clone or download
xleiy Update deploy.md
修改存储默认值
Latest commit 148967c Aug 23, 2019
Permalink
Type Name Latest commit message Commit time
Failed to load latest commit information.
bistoury-agent-common 修改pom版本 Aug 22, 2019
bistoury-agent-task 修改pom版本 Aug 22, 2019
bistoury-agent 修改pom版本 Aug 22, 2019
bistoury-application 修改pom版本 Aug 22, 2019
bistoury-attach-arthas 修改pom版本 Aug 22, 2019
bistoury-attach-common 修改pom版本 Aug 22, 2019
bistoury-clientside-common 修改pom版本 Aug 22, 2019
bistoury-commands 修改pom版本 Aug 22, 2019
bistoury-common 修改pom版本 Aug 22, 2019
bistoury-decompiler-fernflower 修改pom版本 Aug 22, 2019
bistoury-dist 修改pom版本 Aug 22, 2019
bistoury-independent-agent 修改pom版本 Aug 22, 2019
bistoury-instrument-agent 修改pom版本 Aug 22, 2019
bistoury-instrument-client 修改pom版本 Aug 22, 2019
bistoury-instrument-spy 修改pom版本 Aug 22, 2019
bistoury-magic-classes 修改pom版本 Aug 22, 2019
bistoury-magic-loader 修改pom版本 Aug 22, 2019
bistoury-metrics-prometheus 修改pom版本 Aug 22, 2019
bistoury-proxy 修改pom版本 Aug 22, 2019
bistoury-remoting 修改pom版本 Aug 22, 2019
bistoury-serverside-common 修改pom版本 Aug 22, 2019
bistoury-ui-service-impl 修改pom版本 Aug 22, 2019
bistoury-ui-service 修改pom版本 Aug 22, 2019
bistoury-ui 修改pom版本 Aug 22, 2019
docs Update deploy.md Aug 23, 2019
script 注释堆对象统计历史查询入口,修改脚本运行路径,修改zk mock ip地址 Aug 22, 2019
.gitignore init Aug 1, 2019
LICENSE Initial commit Aug 1, 2019
README.md 文档 Aug 21, 2019
pom.xml 修改pom版本 Aug 22, 2019

README.md

Bistoury

GitHub

Bistoury 是去哪儿网开源的一个对应用透明,无侵入的java应用诊断工具,用于提升开发人员的诊断效率和能力。

Bistoury 的目标是一站式java应用诊断解决方案,让开发人员无需登录机器或修改系统,就可以从日志、内存、线程、类信息、调试、机器和系统属性等各个方面对应用进行诊断,提升开发人员诊断问题的效率和能力。

Bistoury 在公司内部原有agent的基础上集成Alibaba开源的arthas和唯品会开源的vjtools,提供了更加丰富的功能,感谢他们做出的优秀工作。

简介

Arthas和vjtools已经是很优秀的工具,我们为什么还要开发Bistoury?

Arthas和vjtools通过命令行或类似的方式使用,不可否认命令行在很多时候具有比较高的效率;但图形化界面也有其自身的优点,特别是在参数复杂时使用起来更加简单,效率更高。Bistoury在保留命令行界面的基础上,还对很多命令提供了图形化界面,方面用户使用。

Arthas和vjtools针对单台机器,从机器的维度对系统进行诊断,没有提供全局的视角;而在线应用往往部署在多台机器,Bistoury可以和使用方应用中心整合,从应用的维度对系统进行诊断,提供了更多的可能。

Arthas和vjtools在使用上,要么登录机器,要么需要使用者提供相应的ip和端口;Bistoury去掉各种设置,提供统一的web入口,从页面上选择应用和机器即可使用。

除了这些针对性优化,Bistoury在保留arthas和vjtools的所有功能之外,还提供了更加丰富的功能。

Bistoury的在线debug功能去掉了各种复杂参数,模拟ide调试体验,通过web界面提供断点调试的功能,可以在不阻塞应用的情况下捕获断点处的信息(包括本地变量、成员变量、静态变量和方法调用栈)。

Bistoury提供了线程级cpu使用率监控,可以监控系统每个线程的分钟级cpu使用率,并提供最近几天的历史数据查询。

Bistoury可以动态对方法添加监控,监控方法的调用次数、异常次数和执行时间,同时也保留最近几天的监控数据。

Bistoury提供了日志查看功能,可以使用tail、grep等命令对单台或同时对多台机器的日志进行查看。

Bistoury提供可视化页面实时查看机器和应用的各种信息,包括主机内存和磁盘使用、cpu使用率和load、系统配置文件、jar包信息、jvm信息、内存使用和gc等等。

快速上手

也许你正面对一个难以捉摸的线上问题束手无策,不妨来试试Bistoury的快捷部署脚本,在一分钟内启动Bistoury然后插入断点开始调试吧!

使用文档

java版本要求

jdk1.8+

系统要求

目前只支持linux系统(支持mac os)

project

欢迎大家各种star,fork,提issue,pull request,感觉还可以就点个star吧!

Q & A

  • jdk版本要求为1.8,但是代码实现很多是1.7

    公司内部使用1.7的jdk,开源版本并没有完全改过来,1.7的代码后续会逐渐修改为1.8的实现。

  • 前端有的地方似乎有点不那么好看,实现的似乎也不太棒

    所有的前端代码都是后端同学兼职完成,欢迎各位前端大牛贡献相关代码。

Screenshots

通过命令行界面查看日志,使用arthas和vjtools的各项功能 console

在线debug,在线应用调试神器 debug

线程级cpu监控,帮助你掌握线程级cpu使用率 jstack_dump

在web界面查看JVM运行信息,以及各种其它信息 jvm

动态给方法添加监控 monitor

线程dump thread_dump

You can’t perform that action at this time.