1)实习经历
2)项目中redis使用了哪些数据结构?哪些场景下用了什么数据结构?怎么考虑的?
3)项目中缓存同步怎么实现的?
我采用的是本地缓存同步(当前微服务的数据库数据与缓存数据同步,可以直接在数据库修改时加入对Redis的修改逻辑,保证数据一致) + 跨服务缓存同步策略(对于服务A调用了服务B,并对查询结果缓存。服务B数据库修改,可以通过rabbitmq通知服务A,服务A修改Redis缓存数据)。另外说了,其实可以使用Canal框架,用来伪装成MySQL的salve节点,监听MySQL的binLog是否变化,然后再去修改Redis缓存数据(但是在项目中没有使用到)
4)接上题,如果在业务中采用异步机制的方式进行缓存同步有哪些问题?
5)Rabbitmq是如何确保消息的不丢失?
6)Rabbitmq如何避免消息堆积问题?
7)Redis分布式锁的底层原理是什么?
8)场景题:分布式集群下有32台redis(主从集群),其中一台redis宕机了,会发生什么问题?一致性Hash的引入解决了什么问题?
9)JDK8的新特性有哪些?
10)JDK8中HashMap的底层实现相比于JDK7做了哪些优化?
11)红黑树的特点?HashMap中为什么使用红黑树?
12)ConcurrentHashMap怎么保证线程安全的?
13)JVM:垃圾回收算法,垃圾回收器,哪些情况下容易发生OOM?如何排查?
14)Java基础:==和equals;封装、继承、多态怎么理解?
15)Spring中IOC的底层过程
16)Sprng中AOP的底层实现
17)singleton和prototype的适用场景有哪些?
18)Http的请求方式有哪些?
19)GET请求和POST请求有哪些区别?对于大数据量的请求使用哪种更好?
20)TCP三次握手过程?为什么使用三次握手而不是两次?
21)算法题:上台阶问题(斐波那契数列),口头描述使用递归和非递归的方式
22)闲聊:最近在看哪些技术栈(云原生&golang);评价下自己;手头上有哪些offer?为什么秋招找了8个offer全都拒了?回答:人嘛,总要有点梦想,万一实现了呢?
反问:多久出通知呢?一个星期后给结果(经典一星期o-o)
总结:回答了9层左右吧,有两个问题没有回答全面。这次面试官比秋招面试好很多,愿意听你说,根据你的回答逐步深入
1) 实习经历
2)Hibernate和mybatis两者的区别是什么?Hibernate的具体使用流程是什么样的?
3)项目中哪些业务场景使用到了redis?项目中提了基于session的共享问题?你是怎么解决的?
4)Redis的常用数据结构,string类型的底层怎么实现的?
5)Redis分布式锁怎么实现的?
6)Java和golang怎么体现面向对象思想的?我从封装,继承,多态三个角度分别进行描述
7)Spring的IOC和AOP底层实现
8)Nginx中的反向代理有哪些规则?在项目中用到了哪些规则?相比于正向代理的区别是什么?
9)Docker容器化是什么?怎么自定义一个镜像上传?dockerfile和compose容器编排了解过吗?
10)Golang的有哪些比较突出的特点?
回答:既有C语言的静态语言程序的运行速度,又能达到Python动态语言的快速开发;自动垃圾回收机制和runtime系统调度机制;强类型和编译性语言,而java是半编译半执行的;不区分平台,运行时不需要依赖外部库;由于goroutine天生支持高并发
11)Goroutine是什么?相比于java中线程或者是OS级别的线程有什么区别?
回答:Go中的并发其实就是函数相互独立运行的能力,Goroutines是一个并发运行的函数。有独立的栈空间,共享程序堆空间,调度由用户自己控制
12)GMP模型?
回答:M代表内核线程,记录内核线程栈信息,当goroutine调度到线程时,使用该goroutine自己的栈信息
P调度器processor,负责调度goroutine,维护一个本地goroutine队列,主线程从调度器上获得goroutine并执行,同时还负责部分内存的管理。(程序启动时创建,P的最大个数由GOMAXPROCS参数来控制)
G表示goroutine,每个goroutine都有自己的栈空间,定时器,初始化的栈空间在2k左右,空间会随着需求增长。
M代表一个工作线程,在M上有一个P和G,P是绑定到M上的,G是通过P的调度获取的,在某一时刻,一个M上只有一个G(g0除外)在P上拥有一个G队列,里面是已经就绪的G,是可以被调度到线程栈上执行的协程,也就是运行队列
13)Go指令的调度流程是什么样的?
回答:
go func()
反问:技术面几轮?3轮