Java必备主流技术流程图

1、Spring的生命周期

Spring作为当前java最流行性、最强大的轻量级容器框架,了解熟悉Spring的生命周期非常有必要

Java必备主流技术流程图_第1张图片

  1. 容器启动后,对bean进行初始化
  2. 按照bean的定义,注入属性
  3. 检测该对象是否实现xxxAware接口,并将相关的xxxAware实例注入给bean,如BeanNameAware等
  4. 以上步骤,bean对象已经正确构造,通过实现BeanPostProcessor接口,可以再进行一些自定义方法处理,如:postProcessBeforeInitialzation
  5. BeanPostProcessor的前置处理完成后,可以实现postConstruct,afterPropertiesSet,init-method等方法,增加我们自定义的逻辑。
  6. 通过实现BeanPostProcessor接口,进行postProcessAfterInitialzation后置处理
  7. 接着Bean准备好被使用啦
  8. 容器关闭后,如果Bean实现了DisposableBean接口,则会回调该接口的destroy()方法
  9. 通过给destroy-method指定函数,就可以在bean销毁前执行指定的逻辑

2、TCP三次握手,四次挥手

tcp的三次握手四次挥手是每个程序员都应该熟悉的。

Java必备主流技术流程图_第2张图片

三次握手
  1. 第一次握手(SYN=1,seq=x),发送完毕后,客户端进入SYN_SEND状态
  2. 第二次握手(SYN=1,ACK=1,seq=y,ACKnum=x+1),发送完毕后,服务器端进入SYN_RCVD状态
  3. 第三次握手(ACK=1,ACKnum=y+1),发送完毕后,客户端进入ESTABLISHED状态,当服务器端接收到这个包时,也进入ESTABLISHED状态,TCP握手,即可以开始数据传输。
四次挥手
  1. 第一次挥手(FIN=1,seq=a),发送完毕后,客户端进入FIN_WAIT_1 状态
  2. 第二次挥手(ACK=1,ACKnum=a+1),发送完毕后,服务器端进入CLOSE_WAIT状态,客户端接收到这个确认包之后,进入FIN_WAIT_2状态
  3. 第三次挥手(FIN=1,seq=b),发送完毕后,服务器端进入LAST_ACK状态,等待来自客户端的最后一个ACK
  4. 第四次挥手(ACK=1,ACKnum=b+1),客户端接收到来自服务器端的关闭请求,发送一个确认包,并进入TIME_WAIT状态,等待了某个固定时间(两个最大段生命周期,2MSL,2 MAXimum Segment Lifetime)之后,没有收到服务器端的ACK,认为服务器端已经正常关闭连接,于是自己也关闭连接,进入CLOSED状态。服务器端接收到这个确认包之后,关闭连接,进入CLOSED状态。

3、线程池执行流程图

线程池:一种线程使用模式。线程过多会带来调度开销,进而影响缓存局部性和整体性能。而线程池维护者多个线程,等待着监督管理者分配可执行的任务,这避免了在处理短时间任务是创建于销毁线程的代价,线程池执行流程是每个开发必备的。

Java必备主流技术流程图_第3张图片

执行流程
  1. 提交一个任务,线程池例存活的核心线程数小于线程数corePoolSize时,线程池会创建一个核心线程去处理提交得任务。
  2. 如果线程池核心线程数已满,即线程数已经等于corePoolSize,一个新提交得任务,会被放进任务队列workQueue排队等待执行。
  3. 当线程池里面存活的线程数已经等于corePoolSize了,并且任务队列workQueue也满了,判断线程数是否达到maximumPoolSize,即最大线程数是否已满,如果没有达到,创建非核心线程执行提交任务。
  4. 如果当前的线程数达到maximumPoolSize,还有新的任务过来得话,直接采用拒绝策略处理
JDK提供了四种拒绝策略处理类
  1. AbortPolicy (抛出一个异常,默认的)
  2. DiscardPolicy (直接丢弃任务)
  3. DiscardOldestPolicy(丢弃队列里最老的任务,将当前任务继续提交给线程池)
  4. CallerRunsPolicy (交给线程池调用所在的线程进行处理)

4、JVM内存结构

Java必备主流技术流程图_第4张图片

程序计数器(PC 寄存器)
  1. 程序计数器是一块较小的内存空间,可以看作当前线程所执行的字节码的行号指示器。在虚拟机模型里,字节码解析工作时就是通过改变这个计数器的值来选取下一条需要执行的字节码指令、分支、循环、异常处理、线程恢复等基础功能都需要依赖计数器完成。
JAVA虚拟机栈
  1. 与程序计数器一样,Java虚拟机栈也是线程私有的,它的生命周期与线程相同
  2. 每个方法被执行的时候都会创建一个“栈帧”,用于存储局部变量表(包括参数)、操作数栈,动态链接、方法出口等信息。每个方法被调用到执行完得过程,就对应着一个栈帧在虚拟机中从入栈到出栈的过程。
  3. 局部变量表存放各种基本数据类型boolean、byte、char、short等
本地方法栈
  1. 与虚拟机栈基本类似,区别在于虚拟机栈为虚拟机执行的java方法服务,而本地方法栈则是为Native方法服务。
Java堆
  1. GC堆是java虚拟机所管理的内存中最大得一块内存区域,也是被各个线程共享的内存区域,在JVM启动时创建。
  2. 其中大小通过-Xms(最小值)和-Xmx(最大值)参数设置,-Xms为JVM启动时申请的最小内存,-Xmx为JVM可申请的最大内存。
  3. 由于现在收集器都是采用分代收集算法,堆被划分为新生代和老年代。新生代由S0和S1构成,可通过-Xmn参数来指定新生代的大小
  4. 所有对象实例以及数组都在堆上分配
  5. Class文件中除了有类的版本、字段、方法、接口等描述信息外,还有一项信息是常量池,用于存放编译器生成的各种符号引用,这部分内容将在类加载后放到方法区的运行时常量池中。
方法区
  1. 也称“永久代”,它用于存储虚拟机加载的类信息、常量、静态变量、是各个线程共享的内存区域。可以通过-XX:PermSize 和 -XX:MaxPermSize 参数限制方法区大小。
  2. 运行时常量池:是方法区的一部分,其中的主要内容来自于JVM对Class的加载。
  3. Class文件中除了有类的版本、字段、方法、接口等描述信息外,还有一项信息是常量池,用于存放编译器生成的各种符号引用,这部分内容将在类加载后放到方法区的运行时常量池中。

5、Java内存模型

Java必备主流技术流程图_第5张图片

  1. Java的多线程之间是通过共享内存进行通信的,在通信过程中会存在一系列如可见性、原子性、顺序性等问题,而JMM就是围绕着多线程通信以及与其相关的一系列特性而建立得模型,JMM定义了一些语法集,这些语法集映射到Java语言中就是volatile、synchronized等关键字。
  2. Java内存模型规定了所有得变量都存储在主内存中,每条线程还有自己的工作内存,线程的工作内存中保存了该线程中进行,而不能直接读写主内存。不同的线程之间也无法直接访问对方工作内存中的变量,线程间变量的传递均需要自己的工作内存和主内存之间进行数据同步进行。

6、springMVC 执行流程图

Java必备主流技术流程图_第6张图片

  1. User向服务器发送request,前端控制Servelt DispatcherServlet捕获;
  2. DispatcherServlet对请求URL进行解析,调用HandlerMapping获得Handler配置HandlerExecutionChain对象的形式返回;
  3. DispatcherServlet 根据获取得Handler,选择一个合适的HandlerAdapter;
  4. 提取Request中的模型数据,填充Handler入参,开始执行Handler(Controller);
  5. Handler执行完成后,返回一个ModelAndView对象到DispatcherServlet
  6. 根据返回的ModelAndView,选择一个合适的ViewResolver;
  7. ViewResolver 结合Model和View,来渲染视图;
  8. 将渲染结果返回给客户端;

7、JDBC执行流程

Java必备主流技术流程图_第7张图片

JDBC执行流程:
  1. 连接数据源
  2. 为数据库传递查询和更新指令
  3. 处理数据库响应并返回的结果

8、Spring Cloud组件架构

Spring Cloud是一个基于Spring Boot实现的云原生应用开发工具,它为基于JVM的云原生应用开发涉及的配置管理、服务发现、熔断器、智能路由、微代理、控制总线、分布式会话和集群状态管理等操作提供一种简单的开发方式

Java必备主流技术流程图_第8张图片

  1. Eureka 负责服务的注册与发现
  2. Hystrix 负责监控服务之间的调用情况,起到熔断,降级作用
  3. Spring Cloud Config 提供了统一得配置中心服务
  4. 所有对外的请求和服务,我们都通过Zuul来进行转发,起到API网关的作用
  5. 最后我们使用Sleuth+Zipkin将所有得请求数据记录下来,方便我们进行后续分析
  6. Spring Cloud Ribbon是基于Netflix Ribbon实现的一套客户端负载均衡的工具。它是一个基于HTTP和TCP的客户端负责均衡器
  7. Feign是一个声明式的Web Service客户端,它的目的就是让Web Service调用更加简单

9、Dubbo 调用

Dubbo是一个分布式服务框架,致力于提供高性能和透明化的远程服务调用方案,这容易和负载均衡器弄混,负载均衡器是对外提供一个公共地址,请求过来时通过轮询、随机等,路由到不同server。

Java必备主流技术流程图_第9张图片

  1. Provider:暴露服务的服务提供方
  2. Consumer:调用远程服务的服务消费方
  3. Registry:服务注册与发现的注册中心
  4. Monitor:统计服务的调用次数和调用时间的监控中心
  5. Container:服务运行容器

你可能感兴趣的:(Java)