# ProjectTree **Repository Path**: mike.hu/ProjectTree ## Basic Information - **Project Name**: ProjectTree - **Description**: 新人熟悉项目必备工具!基于Spring环境开发的一款方法调用链分析框架,简单到只需要一个注解,异步非阻塞,完美嵌入Spring Cloud、Dubbo项目!再也不用担心搞不懂项目! - **Primary Language**: Java - **License**: Apache-2.0 - **Default Branch**: master - **Homepage**: https://github.com/yueshutong - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 26 - **Created**: 2019-09-18 - **Last Updated**: 2020-12-19 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README ![](./picture/220619.png) 很多新人进入一家新公司后,最头疼的就是如何快速了解公司的业务和项目架构。 因为文档很少,没有文档,或者是文档严重落伍, 根本没法看;如果你碰到一个特别热心的老员工,事无巨细地给你讲,随时在你身边答疑解惑, 那简直是天大的好运气, 现实是大家都很忙,没人给你讲解。 很快就要深入项目做开发了,怎么办呢? 我在加入新公司后,就遇到了悲催的情况。于是,我就做了这款可视化流程分析插件!帮助更多入职新人快速熟悉业务。 ## Maven依赖 直接在pom.xml引入依赖! ```xml cn.yueshutong tree-spring-boot-starter 1.0.0.RELEASE ``` 但前提是你已经引入如下依赖: ```xml org.springframework.boot spring-boot-starter-web org.springframework.boot spring-boot-starter-aop ``` ### Spring Boot Starter 如果你的项目是Spring Boot,那么使用会非常简单,只需要一个注解即可。 @EnableProjectTree(value = "")注解参数为[pointcut](https://www.baidu.com/baidu?isource=infinity&iname=baidu&itype=web&tn=98012088_9_dg&ch=7&ie=utf-8&wd=%40pointcut%20%E8%A1%A8%E8%BE%BE%E5%BC%8F)表达式,完整代码如下: ```java @SpringBootApplication @EnableProjectTree("execution(* com.example.springboot.demo..*(..))") public class SpringbootApplication { public static void main(String[] args) { SpringApplication.run(SpringbootApplication.class, args); } } ``` Project Tree不仅增加了对分布式接口的监控,还增加了pointcut表示式。 ### 访问ProjectTree 启动你的项目,首先访问你项目的某个接口,使其执行被监控的方法。然后访问`localhost:8080/tree/project.html`查看网页。 #### 接口说明 | 接口 | 说明 | | ---------------------------- | -------------------- | | /tree/project.html | 返回完整调用链视图 | | /tree/project.html?all=1 | 返回全部方法视图 | | /projecttree/all | JSON形式的返回结果 | | /projecttree/{methodId} | 对某一方法的JSON结果 | ## 注意事项 使用Shiro、Spring Securit等安全框架时,需要注意对此URL的权限控制。 另外,方法调用链分析并不会监控自身对自身的方法调用,因为this.method()并不是调用的代理对象的method()方法。 ## 源码亮点 1.如何降低对主流程的性能消耗? 使用多线程实现异步非阻塞模型。 2.为什么使用单例线程池? 只有一个线程的线程池实际是队列+单线程,一个一个的执行任务,完全符合本框架的使需求,多则出错。 3.为什么数据保存到内存? 基于内存的数据读写,基于方法调用链分析进行选择性保存,占用内存极小。理论上说,从接口开始,有多少流程分支,就有多少条数据记录。 4.如何实现方法调用分析? 基于栈数据结构设计算法。 5.如何解决多线程环境对算法的影响? 通过ThreadId加Stack自定义数据结构“线程栈”实现线程隔离。 ## About Blog: Email:[yster@foxmail.com](mailto:yster@foxmail.com) Github: Gitee: 交流QQ群:781927207 如果帮助到你了,请不吝赞赏!谢谢!