多家大厂 JAVA 面试题整理分布式 + 微服务 + 高并发 + 性能优调 + 框架源码

前段时间一直有粉丝问我,有没有去年一些大厂 Java 面试题总结?最新抽时间整理了一些,分享给大家,大家一起共享学习!

多家大厂 JAVA 面试题整理分布式 + 微服务 + 高并发 + 性能优调 + 框架源码_第1张图片

一、性能调优系列

1.Tomcat 性能调优

JVM 参数调优: -Xms 表示 JVM 初始化堆的大小,一 Xmx表示 JVM 堆的最大值。这两个值的大小一般根据需要进行设置。当应用程序需要的内存超出堆的最大值时虚拟机就会提示内存溢出,并且导致应用服务崩溃。因此- -般建议堆的最大值设置为可用内存的最大值的 80%。在 catalina.bat 中,设置 JAVA _0PTS='-Xms256m-Xmx512m',表示初始化内存为 256MB,可以使用的最大内存 512MB。

多家大厂 JAVA 面试题整理分布式 + 微服务 + 高并发 + 性能优调 + 框架源码_第2张图片

2.JVM 性能调优

Java 类加载过程

Java 类加载需要经历一下 7 个过程:

1.加载

加载是类加载的第一个过程,在这个阶段,将完成一下三件事情

(1)通过一个类的全限定名获取该类的二进制流。

(2)将该二进制流中的静态存储结构转化为方法去运行时数据结构。

(3)在内存中生成该类的 Class 对象,作为该类的数据访问入口。

2.验证

验证的目的是为了确保 Class 文件的字节流中的信息不回危害到虚拟机.在该阶段主要完成以下四钟验证:

(1)文件格式验证:验证字节流是否符合 Class 文件的规范,如主次版本号是否在当前虚拟机范围内,常量池中的常量是否有不被支持的类型.

(2)元数据验证:对字节码描述的信息进行语义分析,如这个类是否有父类,是否集成了不被继承的类等。

(3)字节码验证:是整个验证过程中最复杂的一个阶段,通过验证数据流和控制流的分析,确定程序语义是否正确,主要针对方法体的验证。如:方法中的类型转换是否正确,跳转指令是否正确等。

(4)符号引用验证:这个动作在后面的解析过程中发生,主要是为了确保解析动作能正确执行。

多家大厂 JAVA 面试题整理分布式 + 微服务 + 高并发 + 性能优调 + 框架源码_第3张图片

3.MySQL 性能调优

复制基本原理流程

1. 主:binlog 线程——记录下所有改变了数据库数据的语句,放进 master 上的 binlog 中;

2. 从:io 线程——在使用 start slave 之后,负责从 master 上拉取 binlog 内容,放进 自己的 relay log 中;

3. 从:sql 执行线程——执行 relay log 中的语句;

MySQL 复制的线程有几个及之间的关联

MySQL 的复制是基于如下 3 个线程的交互( 多线程复制里面应该是 4 类线程):

1. Master 上面的 binlog dump 线程,该线程负责将 master 的 binlogevent 传到 slave;

2. Slave 上面的 IO 线程,该线程负责接收 Master 传过来的 binlog,并写入 relay log;

3. Slave 上面的 SQL 线程,该线程负责读取 relay log 并执行;

4. 如果是多线程复制,无论是 5.6 库级别的假多线程还是 MariaDB 或者 5.7 的真正的多线程复制, SQL 线程只做 coordinator,只负责把 relay log 中的 binlog 读出来然后交给 worker 线程, woker 线程负责具体 binlog event 的执行;

你可能感兴趣的:(架构,面试,java,java,分布式,微服务,数据库,面试)