前言
消息中间件是分布式系统中的重要组件,在实际工作中常用消息中间件进行系统间数据交换,从而解决应用解耦、异步消息、流量削峰等问题,实现高性能、高可用、可伸缩和最终一致性架构。目前市面上可供选择的消息中间件有RabbitMQ、ActiveMQ、 Kafka、 RocketMQ、ZeroMQ、MetaMQ等。
本文总结了近年来在实际项目中使用消息中间件的经历和踩过的一些坑,可为你**在实际工作中进行产品选型、业务场景方案制定、性能调整等提供明确的思路。**由于是基于Java语言开发,因此它非常适合Java初中级程序员阅读,学习。
一面:
-
个人介绍加项目介绍20分钟
-
微服务架构是什么,它的优缺点?
-
ACID CAP BASE理论
-
分布式一致性协议,二段、三段、TCC,优缺点
-
RPC过程
-
服务注册中心宕机了怎么办?
-
微服务还有其他什么组件
-
分布式架构与微服务的关系
-
你有什么问题要问我的?
二面:
-
各种排序算法、未排序常规数据查找第K大的数,时间复杂度。
-
二叉树的深度
-
虚拟内存分页了解不?
-
进程和线程区别?
-
第一二三范式是什么?
-
一个表一千个列值为true和false,写sql 查询 有300个列值为true的行。
-
脏读和幻读是什么?
-
什么对象会从新生代晋升到老年代
-
一个任务分成十个任务,最后汇总计算,不能用fork/join
-
开源框架源码了解不?
-
数据建模两道、个人题开放性题
-
对安全方面了解多少?
-
安全协议有哪些 、https是啥?
-
介绍你做的项目和其中的难点。
三面:
-
从ConcurrentHashMap一路问到锁&锁优化->LongAdder->伪共享->缓存行填充->cas等诸多技术细节;
-
从hystrix一路问到原理->自己如何实现->如何优化->响应流编程(reactive streams);
-
从简单的生产者消费者模式设计到如何高效健壮实现等等。
四面:
-
如何倒序输出单向链表?
-
个人直接想法是用栈先进后出的特点,把链表数据读到栈里然后输出。
-
有更好的实现方式吗?
-
主要问项目情况,然后根据一个项目,问如果量级扩大1000倍,你会怎么做?有哪些优化措施?高性能&高可用措施?
五面:
-
个人的职业规划是什么?
-
你遇到的最大问题或者是困难是什么?
-
你如何看待我们公司?
-
你能为我们公司带来什么?
-
你的优缺点是什么?
面试总结:
-
技术基础必须扎实:算法、数据结构、操作系统等,蚂蚁金服面试对技术的基础非常重视,基础扎实的同学有利于在前两轮突出重围。
-
技术宽度:主要集中在高并发、多线程、分布式架构,大以及常用中间件(缓存等)的选型和比较。
-
技术原理深入:重点还是提前准备好JVM、多线程高并发这块。
-
参与的项目总结:你需要清楚你所做项目的关键细节、优化、特点、原理。
-
很多所用第三方库&中间件等的原理,即使你不知道,也要有自己的想法能够说出如何代替实现,比如单点登录的替代方案。
《一线大厂Java面试真题解析+Java核心总结学习笔记+最新全套讲解视频+实战项目源码》开源
Java开发优秀开源项目:
ali1024.coding.net/public/P7/Java/git
github.com/spring-projects
最后
文章中涉及到的知识点我都已经整理成了资料,录制了视频供大家下载学习,诚意满满,希望可以帮助在这个行业发展的朋友,在论坛博客等地方少花些时间找资料,把有限的时间,真正花在学习上,所以我把这些资料,分享出来。相信对于已经工作和遇到技术瓶颈的朋友们,在这份资料中一定都有你需要的内容。
大家下载学习,诚意满满,希望可以帮助在这个行业发展的朋友,在论坛博客等地方少花些时间找资料,把有限的时间,真正花在学习上,所以我把这些资料,分享出来。相信对于已经工作和遇到技术瓶颈的朋友们,在这份资料中一定都有你需要的内容。**