1. 菜鸟补录面试

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层左右吧,有两个问题没有回答全面。这次面试官比秋招面试好很多,愿意听你说,根据你的回答逐步深入

2. 知乎一面(golang开发)

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轮