dubbo+zookeeper原理,小米java校招面试

这篇文章汇总了阿里巴巴面试中常见的技术问题,涉及Java内存管理、多线程、数据库优化、网络IO、Spring框架、并发编程、Mybatis与SQL调优等内容,以及面试技巧和资源推荐。
摘要由CSDN通过智能技术生成

一面:

阿里巴巴面试答案文末可以领取!

1. 触发新生代GC,如果存活对象总量大于survivor区容量,咋办

2. 如果任务很多,线程池的阻塞队列会撑爆内存的哪个区域

3. 栈在堆上吗

4. GC root有哪些

5. 实例变量可以是GC root吗

6. 了解哪些GC算法,介绍一下

7. 给个场景,问怎么设置JVM参数

8. 问了很多SQL调优,各种语句能不能命中索引,能命中哪些,怎么优化

9. MySQL的一张表里有三个字段ABC,A的种类有1000种,B有1W种,C有10W种,ABC的联合索引怎么设置,怎么使用

10. Mybatis # 和 $ 的区别

11. Mybatis接口里的方法和XML里的SQL名可以不一样吗,不一样怎么办

12. Mybatis是如何完成SQL和接口里的方法的映射的(我回答了怎么配置),那你知道它是怎么实现的吗

13. 介绍下Spring的 IOC和AOP

14. 服务器给客户端发送IO流的过程

15. IO和NIO了解多少

16. 线程都有哪些状态,怎么转换的

17. Notify和notifyAll的区别

18. 介绍线程池,不同线程池区别在哪,你平时怎么使用线程池的

19. MySQL索引的数据结构

20. B+树了解多少

21. Cookie和SessionId说一下

22. 锁是怎么实现的

23. Synchronized同步块和synchronized方法,分别锁的是什么

24. 单例模式,饿汉和懒汉分别存在的问题

25. Volatile是怎么实现可见性的

26. 介绍下JMM

27. Happen before了解吗

28. A happen before B,意味着A一定在B之前执行吗

29. 你做过的最难的项目中,最难的任务是什么,怎么解决的

二面:

1. 看过哪些源码

2. Java都有哪些map,分别怎么实现的,具体讲

3. 除了LinkedHashMap,你还知道哪些有序map

4. ConcurrentHashMap讲一讲

5. 为什么要有线程池

6. 线程池有哪几类?有什么区别?有哪些参数?拒绝策略有哪些

7. 阻塞队列都有哪几种,有什么区别

8. Java的反射怎么理解

9. Spring的IOC和AOP怎么理解

10. Spring项目启动的时候会加载哪些资源,顺序是怎么样的

11. 浏览器输入一个URL,会发生什么,整个过程说一下

12. Http讲一讲,请求有哪些内容,响应有哪些内容

三面(leader面):

1. MySQL的高可用了解多少,高性能了解多少

2. 淘宝有1000T的数据,单机存不下,怎么办?有没有办法只访问一次服务器?一致性Hash懂多少

3. MySQL和redis有啥区别

4. MySQL数据备份怎么做

5. Redis底层原理会多少

6. Redis为啥比MySQL快

7. Redis RDB可能会丢失数据,怎么办

8. Redis AOF不也要把日志写到磁盘么,那和MySQL的IO有啥区别,凭啥Redis就快

9. Redis主从复制怎么做

10. 分布式缓存懂多少

11. 还知道其他NoSQL么

12. Java和C的优缺点说一下

13. 有没有用C写过底层

14. Java的G1回收器详细讲一讲

15. G1什么时候会stop the world

16. Linux操作系统有应用过吗

17. 对分布式和中间件掌握多少

18. 详细介绍下你的项目

四面:

1. 数据库索引常用的数据结构

2. Juc源码看过吗?锁的实现原理是什么

3. CAS能深入的说一下吗

4. 建造者模式说一下

5. 谈一谈笔试的心得(笔试分高)

6. 看过哪些书籍

7. 平时怎么学习的

五面(交叉面):

1. 介绍下项目,项目的来源,是自己一个人做的么

2. 登录验证怎么做的

3. 讲一讲ThreadLocal

4. ThreadLocal怎么避免线程污染

5. 点赞怎么实现的

6. Redis持久化方式

7. MySQL存储引擎区别

8. Myisam在只读场景下,为什么一般比InnoDB快

9. Mybatis怎么使用

10. Mybatis # 和 $ 的区别

11. Spring中BeanFactory和ApplicationContext的区别

12. Spring中bean的作用域有哪些,有什么区别

13. 说出一个原型作用域的具体应用场景

14. 学习过哪些设计模式,用过哪些设计模式

15. 生产者消费者模式讲一讲

16. 怎么实现阻塞队列

17. 学过Linux吗

18. 在Linux下,怎么查找一个目录下的所有文件,要求输出顺序按照文件的创建时间排序

19. 给你一堆学生的信息,包括学号和姓名,让你找出学号最靠前的10个人的姓名

20. PriorityQueue怎么实现的

21. 怎么求根号3(我说了二分法,用2的平方,1.5的平方,1.75的平方依次和3比较,缩小区间,直到达到精度要求)

22. 你这种求法太慢了,可以优化吗(我问:您是想问数值分析的知识么?面试官说:是的,你没学过数值分析么?)

23. 斐波那契数列,求第n项的值(答了递归和DP两种方式)

24. 如果数列长度100W,你的DP矩阵不是很大么?怎么优化?(答:用两个变量a,b记录前两个值,temp = a, a = b, b = a + temp,依次递推)

25. 一个时钟有时针分针和秒针,三针重合的最短时间间隔是多少?(完全没思路,只知道一小时内肯定不行,因为走得速度不一样,一圈内速度快的和速度慢的撞不上)

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Java)

读者福利

分享一份自己整理好的Java面试手册,还有一些面试题pdf

不要停下自己学习的脚步

字节跳动的面试分享,为了拿下这个offer鬼知道我经历了什么

字节跳动的面试分享,为了拿下这个offer鬼知道我经历了什么

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
不要停下自己学习的脚步*

[外链图片转存中…(img-7eLD4HOx-1713777639044)]

[外链图片转存中…(img-flMvmVb6-1713777639045)]

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

Dubbo + Zookeeper 的项目启动顺序大致可以分为以下几个步骤: 1. **Zookeeper 启动**:首先,需要启动Zookeeper服务。这是集群管理的基础,用于协调分布式系统中各个节点的状态和服务发现。 2. **注册中心(Zookeeper作为注册中心)配置**:接下来,在Dubbo项目的配置文件中设置Zookeeper作为注册中心的信息,包括Zookeeper的地址、端口等信息。这一步决定了Dubbo应用如何通过Zookeeper与服务提供者和消费者交互。 3. **服务提供者启动**:服务提供者启动时,会向注册中心(即Zookeeper)注册其提供的服务。这里的注册过程包含了两个关键步骤: - **检查点**:在启动服务之前,通常会先检查某个状态点(如某个目录路径),以确保所有必要的组件已经就绪并正常运行。 - **注册服务**:服务提供者将自身的服务信息(例如服务名、版本、实现类等)注册到Zookeeper上,形成服务目录树结构,方便后续服务查找。 4. **服务消费者启动**:服务消费者在启动时,会从注册中心查询可用的服务列表。这个过程中可能会涉及到缓存机制,减少对注册中心的频繁访问压力。当消费者发现目标服务后,会建立连接并准备调用服务。 5. **服务调用**:在完成以上步骤之后,消费者就可以通过创建的连接调用提供者的服务了。Dubbo会负责处理服务调用的过程,包括序列化数据、网络传输、远程调用、异常处理等。 6. **关闭资源**:最后,在程序结束前,应确保所有资源得到正确的释放,避免内存泄漏或其他潜在的问题。 在这个过程中,Zookeeper 作为核心的协调服务,保证了服务提供者和服务消费者的稳定通信,并实现了动态服务发现的功能。Dubbo框架则提供了高效、易用的RPC(Remote Procedure Call)机制,使得服务间的调用更为便捷和可靠。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值