前言
现如今的互联网应用大都是采用 分布式系统架构 设计的,所以 消息队列 已经逐渐成为企业的应用系统 内部通信 的核心手段,
它具有 低耦合、可靠投递、广播、流量控制、最终一致性 等一系列功能。
当前使用较多的 消息队列 有 RabbitMQ、RocketMQ、ActiveMQ、Kafka、ZeroMQ、MetaMQ 等,而部分数据库 如 Redis、MySQL 以及 phxsql ,如果硬搞的话,其实也可实现消息队列的功能。
可能有人觉得,各种开源的 MQ 已经足够使用了,为什么需要用 Redis 实现 MQ 呢?
- 有些简单的业务场景,可能不需要重量级的 MQ 组件(相比 Redis 来说,Kafka 和 RabbitMQ 都算是重量级的消息队列)
那你有考虑过用 Redis 做消息队列吗?
这一章,我会结合消息队列的特点和 Redis 做消息队列的使用方式,以及实际项目中的使用,来和大家探讨下 Redis 消息队列的方案。
准备好套路
**①自我介绍:**千万不能筐瓢,一定要牢记,自然流畅地介绍自己的学习经历、工作经历、项目经历、个人优势等等;
**②抽象概念:**当面试官问你是如何理解多线程的时候,你要知道从定义、来源、实现、问题、优化、应用方面系统性地回答;
**③项目强化:**必须针对简历中的两个以上的项目,形成包括【架构和实现细节】,【正常流程和异常流程的处理】,【难点+坑+复盘优化】三位一体的组合拳;
**④压力练习:**面试紧张难免,尤其是面试这种大公司,可能会严重影响发挥,建议多面一些有把握的公司,训练自己的心态,也可以通过平时多找机会参与交流分享,或找人做压力面试来改善;
**⑤表达能力:**表达能力在面试中非常重要,表达不好非常容易拉低面试官的印象,面试时应该简练、自然顺畅地将答案告诉面试官;
**⑥重点针对:**面试官会针对简历提问,所以请针对简历上写的所有技术点进行重点准备。
Java基础面试总结
①JVM原理
②集合
③多线程
④IO
⑤问题排查
Web框架、数据库
①Spring
②MySQL
③Redis
通用基础
①操作系统
②网络通信协议
③排序算法
④常用设计模式
⑤从URL到看到网页的过程
分布式
①CAP理
②锁
③事务
④消息队列
⑤协调器
⑥ID生成方式
⑦一致性hash
微服务
①微服务介绍
②服务发现
③API网关
④服务容错保护
⑤服务配置中心
算法(字节必问)
①数组-快速排序-第k大个数
②数组-对撞指针-最大蓄水
③数组-滑动窗口-最小连续子数组
④数组-归并排序-合并有序数组
⑤链表-链表反转-链表相加
⑥链表-双指针-删除倒数第n个
⑦二叉树-递归-二叉树反转
⑧动态规划-连续子数组最大和
⑨数据结构-LRU淘汰算法
项目举例
①秒杀架构
系统设计
①系统设计-高并发抢红包
②系统设计-答题套路
③系统设计-在AWS上扩展到数百万用户的系统
④系统设计-从面试者角度设计一个系统设计题
总结
互联网大厂比较喜欢的人才特点:对技术有热情,强硬的技术基础实力;主动,善于团队协作,善于总结思考。无论是哪家公司,都很重视高并发高可用技术,重视基础,所以千万别小看任何知识。面试是一个双向选择的过程,不要抱着畏惧的心态去面试,不利于自己的发挥。同时看中的应该不止薪资,还要看你是不是真的喜欢这家公司,是不是能真的得到锻炼。其实我写了这么多,只是我自己的总结,并不一定适用于所有人,相信经过一些面试,大家都会有这些感触。