很多同學(xué)會(huì)問Java面試八股文有必要背嗎?
我的回答是:很有必要。你可以討厭這種模式,但你一定要去背,因?yàn)椴槐衬憔瓦M(jìn)不了大廠。
國(guó)內(nèi)的互聯(lián)網(wǎng)面試,恐怕是現(xiàn)存的、最接近科舉考試的制度。
(相關(guān)資料圖)
而且,我國(guó)的八股文確實(shí)是獨(dú)樹一幟。以美國(guó)為例,北美工程師面試比較重視算法(Coding),近幾年也會(huì)加入Design輪(系統(tǒng)設(shè)計(jì)和面向?qū)ο笤O(shè)計(jì)OOD)和BQ輪(Behavioral question,行為面試問題)。
那么為什么國(guó)內(nèi)面試不采取這樣的考察方式呢?簡(jiǎn)單來(lái)說(shuō),互聯(lián)網(wǎng)IT行業(yè)的求職者太多了,如果考察的是清一溜的算法題和設(shè)計(jì)題,那么會(huì)要求面試官有極高的技術(shù)水平,還要花大量的時(shí)間成本和精力。
也許現(xiàn)行的八股文面試不是最優(yōu)的解法,但的確是最符合當(dāng)前國(guó)內(nèi)IT環(huán)境的做法。
所以,我采訪了超過(guò)20位資深大廠面試官后,一直在盡量精煉準(zhǔn)確的整理一套切實(shí)可行的八股文,現(xiàn)在已經(jīng)有329位粉絲通過(guò)這套題走入了理想的崗位,所以分享出來(lái)給大伙看看,有什么不足之處歡迎評(píng)論補(bǔ)充。
篇幅所限本文就只貼一下題目了,同學(xué)們可以自己先看看有哪些題是會(huì)的,答案的話我整理的一本《Java面試八股文》PDF里都有,
一、Java基礎(chǔ) 44 道
1. 解釋下什么是面向?qū)ο??面向?qū)ο蠛兔嫦蜻^(guò)程的區(qū)別?
2. 面向?qū)ο蟮娜筇匦??分別解釋下?
3. JDK、JRE、JVM 三者之間的關(guān)系?
4. 重載和重寫的區(qū)別?
5. Java 中是否可以重寫一個(gè) private 或者 static 方法?
6. 構(gòu)造方法有哪些特性?
7. 在 Java 中定義一個(gè)不做事且沒有參數(shù)的構(gòu)造方法有什么作用?
8. Java 中創(chuàng)建對(duì)象的幾種方式?
9. 抽象類和接口有什么區(qū)別?
10. 靜態(tài)變量和實(shí)例變量的區(qū)別?
11. 12、short s1 = 1;s1 = s1 + 1;有什么錯(cuò)?那么 short s1 = 1; s1 += 1;呢?有沒有錯(cuò)誤?
12. Integer 和 int 的區(qū)別?
13. 裝箱和拆箱的區(qū)別
14. switch 語(yǔ)句能否作用在 byte 上,能否作用在 long 上,能否作用在 String 上?
15. 16、final、finally、finalize 的區(qū)別
16. == 和 equals 的區(qū)別?
17. 兩個(gè)對(duì)象的 hashCode() 相同,則 equals() 也一定為 true 嗎?
18. 為什么重寫 equals() 就一定要重寫 hashCode() 方法?
19. & 和 && 的區(qū)別?
20. Java 中的參數(shù)傳遞時(shí)傳值呢?還是傳引用?
21. Java 中的 Math.round(-1.5) 等于多少?
22. 如何實(shí)現(xiàn)對(duì)象的克???
23. 深克隆和淺克隆的區(qū)別?
24. 什么是 Java 的序列化,如何實(shí)現(xiàn) Java 的序列化?
25. 什么情況下需要序列化?
26. Java 的泛型是如何工作的 ? 什么是類型擦除 ?
27. 什么是泛型中的限定通配符和非限定通配符 ?
28. List 和 List 之間有什么區(qū)別 ?
29. Java 中的反射是什么意思?有哪些應(yīng)用場(chǎng)景?
30. 反射的優(yōu)缺點(diǎn)?
31. Java 中的動(dòng)態(tài)代理是什么?有哪些應(yīng)用?
32. 怎么實(shí)現(xiàn)動(dòng)態(tài)代理?
33. static 關(guān)鍵字的作用?
34. super 關(guān)鍵字的作用?
35. 字節(jié)和字符的區(qū)別?
36. String 為什么要設(shè)計(jì)為不可變類?
37. String、StringBuilder、StringBuffer 的區(qū)別?
38. String 字符串修改實(shí)現(xiàn)的原理?
39. String str = "i" 與 String str = new String("i") 一樣嗎?
40. String 類的常用方法都有那些?
41. final 修飾 StringBuffer 后還可以 Append 嗎?
42. Java 中的 IO 流的分類?說(shuō)出幾個(gè)你熟悉的實(shí)現(xiàn)類?
43. 字節(jié)流和字符流有什么區(qū)別?
44. BIO、NIO、AIO 有什么區(qū)別?
二、Java異常 9 道
1. finally 塊中的代碼什么時(shí)候被執(zhí)行?
2. finally 是不是一定會(huì)被執(zhí)行到?
3. try-catch-finally 中,如果 catch 中 return 了,finally 還會(huì)執(zhí)行嗎?
4. try-catch-finally 中那個(gè)部分可以省略?
5. Error 和 Exception 的區(qū)別?
6. 運(yùn)行時(shí)異常與受檢異常有何異同?
7. throw 和 throws 的區(qū)別?
8. 常見的異常類有哪些?
9. 主線程可以捕獲到子線程的異常嗎?
三、Java集合 24 道
1. Java 中常用的容器有哪些?
2. ArrayList 和 LinkedList 的區(qū)別?
3. ArrayList 實(shí)現(xiàn) RandomAccess 接口有何作用?為何 LinkedList 卻沒實(shí)現(xiàn)這個(gè)接口?
4. ArrayList 的擴(kuò)容機(jī)制?
5. Array 和 ArrayList 有何區(qū)別?什么時(shí)候更適合用 Array?
6. HashMap 的實(shí)現(xiàn)原理/底層數(shù)據(jù)結(jié)構(gòu)?JDK1.7 和 JDK1.8
7. HashMap 的 put 方法的執(zhí)行過(guò)程?
8. HashMap 的 get 方法的執(zhí)行過(guò)程?
9. HashMap 的 resize 方法的執(zhí)行過(guò)程?
10. HashMap 的 size 為什么必須是 2 的整數(shù)次方?
11. HashMap 多線程死循環(huán)問題?
12. HashMap 的 get 方法能否判斷某個(gè)元素是否在 map 中?
13. HashMap 與 HashTable 的區(qū)別是什么?
14. HashMap 與 ConcurrentHashMap 的區(qū)別是什么?
15. HashTable 和 ConcurrentHashMap 的區(qū)別?
16. ConcurrentHashMap 的實(shí)現(xiàn)原理是什么?
17. HashSet 的實(shí)現(xiàn)原理?
18. HashSet 怎么保證元素不重復(fù)的?
19. LinkedHashMap 的實(shí)現(xiàn)原理?
20. Iterator 怎么使用?有什么特點(diǎn)?
21. Iterator 和 ListIterator 有什么區(qū)別?
22. Iterator 和 Enumeration 接口的區(qū)別?
23. fail-fast 與 fail-safe 有什么區(qū)別?
24. Collection 和 Collections 有什么區(qū)別?
四、Java并發(fā) 42 道
1. 并行和并發(fā)有什么區(qū)別?
2. 線程和進(jìn)程的區(qū)別?
3. 守護(hù)線程是什么?
4. 創(chuàng)建線程的幾種方式?
5. Runnable 和 Callable 有什么區(qū)別?
6. 線程狀態(tài)及轉(zhuǎn)換?
7. sleep() 和 wait() 的區(qū)別?
8. 線程的 run() 和 start() 有什么區(qū)別?
9. 在 Java 程序中怎么保證多線程的運(yùn)行安全?
10. Java 線程同步的幾種方法?
11. Thread.interrupt() 方法的工作原理是什么?
12. 談?wù)剬?duì) ThreadLocal 的理解?
13. 在哪些場(chǎng)景下會(huì)使用到 ThreadLocal?
14. 說(shuō)一說(shuō)自己對(duì)于 synchronized 關(guān)鍵字的了解?
15. 如何在項(xiàng)目中使用 synchronized 的?
16. 說(shuō)說(shuō) JDK1.6 之后的 synchronized 關(guān)鍵字底層做了哪些優(yōu)化,可以詳細(xì)介紹一下這些優(yōu)化嗎?
17. 談?wù)?synchronized 和 ReenTrantLock 的區(qū)別?
18. synchronized 和 volatile 的區(qū)別是什么?
19. 談一下你對(duì) volatile 關(guān)鍵字的理解?
20. 說(shuō)下對(duì) ReentrantReadWriteLock 的理解?
21. 說(shuō)下對(duì)悲觀鎖和樂觀鎖的理解?
22. 樂觀鎖常見的兩種實(shí)現(xiàn)方式是什么?
23. 樂觀鎖的缺點(diǎn)有哪些?
24. CAS 和 synchronized 的使用場(chǎng)景?
25. 簡(jiǎn)單說(shuō)下對(duì) Java 中的原子類的理解?
26. atomic 的原理是什么?
27. 說(shuō)下對(duì)同步器 AQS 的理解?
28. AQS 的原理是什么?
29. AQS 對(duì)資源的共享模式有哪些?
30. AQS 底層使用了模板方法模式,你能說(shuō)出幾個(gè)需要重寫的方法嗎?
31. 說(shuō)下對(duì)信號(hào)量 Semaphore 的理解?
32. CountDownLatch 和 CyclicBarrier 有什么區(qū)別?
33. 說(shuō)下對(duì)線程池的理解?為什么要使用線程池?
34. 創(chuàng)建線程池的參數(shù)有哪些?
35. 如何創(chuàng)建線程池?
36. 線程池中的的線程數(shù)一般怎么設(shè)置?需要考慮哪些問題?
37. 執(zhí)行 execute() 方法和 submit() 方法的區(qū)別是什么呢?
38. 說(shuō)下對(duì) Fork和Join 并行計(jì)算框架的理解?
39. JDK 中提供了哪些并發(fā)容器?
40. 談?wù)剬?duì) CopyOnWriteArrayList 的理解?
41. 談?wù)剬?duì) BlockingQueue 的理解?分別有哪些實(shí)現(xiàn)類?
42. 談?wù)剬?duì) ConcurrentSkipListMap 的理解?
五、Java JVM 42 道
1. 說(shuō)一下 Jvm 的主要組成部分?及其作用?
2. 談?wù)剬?duì)運(yùn)行時(shí)數(shù)據(jù)區(qū)的理解?
3. 堆和棧的區(qū)別是什么?
4. 堆中存什么?棧中存什么?
5. 為什么要把堆和棧區(qū)分出來(lái)呢?棧中不是也可以存儲(chǔ)數(shù)據(jù)嗎?
6. Java 中的參數(shù)傳遞時(shí)傳值呢?還是傳引用?
7. Java 對(duì)象的大小是怎么計(jì)算的?
8. 對(duì)象的訪問定位的兩種方式?
9. 判斷垃圾可以回收的方法有哪些?
10. 垃圾回收是從哪里開始的呢?
11. 被標(biāo)記為垃圾的對(duì)象一定會(huì)被回收嗎?
12. 談?wù)剬?duì) Java 中引用的了解?
13. 談?wù)剬?duì)內(nèi)存泄漏的理解?
14. 內(nèi)存泄露的根本原因是什么?
15. 舉幾個(gè)可能發(fā)生內(nèi)存泄漏的情況?
16. 盡量避免內(nèi)存泄漏的方法?
17. 常用的垃圾收集算法有哪些?
18. 為什么要采用分代收集算法?
19. 分代收集下的年輕代和老年代應(yīng)該采用什么樣的垃圾回收算法?
20. 什么是浮動(dòng)垃圾?
21. 什么是內(nèi)存碎片?如何解決?
22. 常用的垃圾收集器有哪些?
23. 談?wù)勀銓?duì) CMS 垃圾收集器的理解?
24. 談?wù)勀銓?duì) G1 收集器的理解?
25. 說(shuō)下你對(duì)垃圾回收策略的理解/垃圾回收時(shí)機(jī)?
26. 談?wù)勀銓?duì)內(nèi)存分配的理解?大對(duì)象怎么分配?空間分配擔(dān)保?
27. 說(shuō)下你用過(guò)的 JVM 監(jiān)控工具?
28. 如何利用監(jiān)控工具調(diào)優(yōu)?
29. JVM 的一些參數(shù)?
30. 談?wù)勀銓?duì)類文件結(jié)構(gòu)的理解?有哪些部分組成?
31. 談?wù)勀銓?duì)類加載機(jī)制的了解?
32. 類加載各階段的作用分別是什么?
33. 有哪些類加載器?分別有什么作用?
34. 類與類加載器的關(guān)系?
35. 談?wù)勀銓?duì)雙親委派模型的理解?工作過(guò)程?為什么要使用
36. 怎么實(shí)現(xiàn)一個(gè)自定義的類加載器?需要注意什么?
37. 怎么打破雙親委派模型?
38. 有哪些實(shí)際場(chǎng)景是需要打破雙親委派模型的?
39. 談?wù)勀銓?duì)編譯期優(yōu)化和運(yùn)行期優(yōu)化的理解?
40. 為何 HotSpot 虛擬機(jī)要使用解釋器與編譯器并存的架構(gòu)?
41. 說(shuō)下你對(duì) Java 內(nèi)存模型的理解?
42. 內(nèi)存間的交互操作有哪些?需要滿足什么規(guī)則?
六、SSM框架 37 道
1. 使用 Spring 框架的好處是什么?
2. 解釋下什么是 AOP?
3. AOP 的代理有哪幾種方式?
4. 怎么實(shí)現(xiàn) JDK 動(dòng)態(tài)代理?
5. AOP 的基本概念:切面、連接點(diǎn)、切入點(diǎn)等?
6. 通知類型(Advice)型(Advice)有哪些?
7. 談?wù)勀銓?duì) IOC 的理解?
8. Bean 的生命周期?
9. Bean 的作用域?
10. Spring 中的單例 Bean 的線程安全問題了解嗎?
11. 談?wù)勀銓?duì) Spring 中的事物的理解?
12. Spring 中的事務(wù)隔離級(jí)別?
13. Spring 中的事物傳播行為?
14. Spring 常用的注入方式有哪些?
15. Spring 框架中用到了哪些設(shè)計(jì)模式?
16. ApplicationContext 通常的實(shí)現(xiàn)有哪些?
17. 談?wù)勀銓?duì) MVC 模式的理解?
18. SpringMVC 的工作原理/執(zhí)行流程?
19. SpringMVC 的核心組件有哪些?
20. SpringMVC 常用的注解有哪些?
21. @RequestMApping 的作用是什么?
22. 如何解決 POST 請(qǐng)求中文亂碼問題,GET 的又如何處理呢?
23. SpringMVC 的控制器是不是單例模式,如果是會(huì)有什么問題,怎么解決?
24. SpringMVC 怎么樣設(shè)定重定向和轉(zhuǎn)發(fā)的?
25. SpringMVC 里面攔截器是怎么寫的?
26. SpringMVC 和 Struts2 的區(qū)別有哪些?
27. 談?wù)勀銓?duì) MyBatis 的理解?
28. MyBaits 的優(yōu)缺點(diǎn)有哪些?
29. MyBatis 與 Hibernate 有哪些不同?
30. MyBatis 中 #{} 和 ${}的區(qū)別是什么?
31. MyBatis 是如何進(jìn)行分頁(yè)的?分頁(yè)插件的原理是什么?
32. MyBatis 有幾種分頁(yè)方式?
33. MyBatis 邏輯分頁(yè)和物理分頁(yè)的區(qū)別是什么?
34. MyBatis 是否支持延遲加載?如果支持,它的實(shí)現(xiàn)原理是什么?
35. 說(shuō)一下 MyBatis 的一級(jí)緩存和二級(jí)緩存?
36. Mybatis 有哪些執(zhí)行器(Executor)?
37. MyBatis 動(dòng)態(tài) SQL 是做什么的?都有哪些動(dòng)態(tài) SQL?能簡(jiǎn)述一下動(dòng)態(tài) SQL的執(zhí)行原理不?
七、MySQL 31 道
1. 請(qǐng)說(shuō)下你對(duì) MySQL 架構(gòu)的了解?
2. 一條 SQL 語(yǔ)句在數(shù)據(jù)庫(kù)框架中的執(zhí)行流程?
3. 數(shù)據(jù)庫(kù)的三范式是什么?
4. char 和 varchar 的區(qū)別?
5. varchar(10) 和 varchar(20) 的區(qū)別?
6. 談?wù)勀銓?duì)索引的理解?
7. 索引的底層使用的是什么數(shù)據(jù)結(jié)構(gòu)?
8. 談?wù)勀銓?duì) B+ 樹的理解?
9. 為什么 InnoDB 存儲(chǔ)引擎選用 B+ 樹而不是 B 樹呢?
10. 談?wù)勀銓?duì)聚簇索引的理解?
11. 談?wù)勀銓?duì)哈希索引的理解?
12. 談?wù)勀銓?duì)覆蓋索引的認(rèn)識(shí)?
13. 索引的分類?
14. 談?wù)勀銓?duì)最左前綴原則的理解?
15. 怎么知道創(chuàng)建的索引有沒有被使用到?或者說(shuō)怎么才可以知道這條語(yǔ)句運(yùn)行很慢的原因?
16. 什么情況下索引會(huì)失效?即查詢不走索引?
17. 查詢性能的優(yōu)化方法?
18. InnoDB 和 MyISAM 的比較?
19. 談?wù)勀銓?duì)水平切分和垂直切分的理解?
20. 主從復(fù)制中涉及到哪三個(gè)線程?
21. 主從同步的延遲原因及解決辦法?
22. 談?wù)勀銓?duì)數(shù)據(jù)庫(kù)讀寫分離的理解?
23. 請(qǐng)你描述下事務(wù)的特性?
24. 談?wù)勀銓?duì)事務(wù)隔離級(jí)別的理解?
25. 解釋下什么叫臟讀、不可重復(fù)讀和幻讀?
26. MySQL 默認(rèn)的隔離級(jí)別是什么?
27. 談?wù)勀銓?duì)MVCC 的了解?
28. 說(shuō)一下 MySQL 的行鎖和表鎖?
29. InnoDB 存儲(chǔ)引擎的鎖的算法有哪些?
30. MySQL 問題排查都有哪些手段?
31. MySQL 數(shù)據(jù)庫(kù) CPU 飆升到 500% 的話他怎么處理?
八、Redis 12 道
1. 談下你對(duì) Redis 的了解?
2. Redis 一般都有哪些使用場(chǎng)景?
3. Redis 有哪些常見的功能?
4. Redis 支持的數(shù)據(jù)類型有哪些?
5. Redis 為什么這么快?
6. 什么是緩存穿透?怎么解決?
7. 什么是緩存雪崩?該如何解決?
8. 怎么保證緩存和數(shù)據(jù)庫(kù)數(shù)據(jù)的一致性?
9. Redis 持久化有幾種方式?
10. Redis 怎么實(shí)現(xiàn)分布式鎖?
11. Redis 淘汰策略有哪些?
12. Redis 常見性能問題和解決方案?
九、計(jì)算機(jī)網(wǎng)絡(luò) 45 道
1. 為什么需要三次握手??jī)纱尾恍校?/p>
2. 為什么需要四次揮手?三次不行?
3. TCP與UDP有哪些區(qū)別?各自應(yīng)用場(chǎng)景?
4. HTTP1.0,1.1,2.0 的版本區(qū)別
5. POST和GET有哪些區(qū)別?各自應(yīng)用場(chǎng)景?
6. HTTP 哪些常用的狀態(tài)碼及使用場(chǎng)景?
7. HTTP狀態(tài)碼301和302的區(qū)別,都有哪些用途?
8. 在交互過(guò)程中如果數(shù)據(jù)傳送完了,還不想斷開連接怎么辦,怎么維持?
9. HTTP 如何實(shí)現(xiàn)長(zhǎng)連接?在什么時(shí)候會(huì)超時(shí)?
10. TCP 如何保證有效傳輸及擁塞控制原理
11. IP地址有哪些分類?
12. GET請(qǐng)求中URL編碼的意義
13. 什么是SQL 注入?舉個(gè)例子?
14. 談一談 XSS 攻擊,舉個(gè)例子?
15. 講一下網(wǎng)絡(luò)五層模型,每一層的職責(zé)?
16. 簡(jiǎn)單說(shuō)下 HTTPS 和 HTTP 的區(qū)別
17. 對(duì)稱加密與非對(duì)稱加密的區(qū)別
18. 簡(jiǎn)單說(shuō)下每一層對(duì)應(yīng)的網(wǎng)絡(luò)協(xié)議有哪些?
19. ARP 協(xié)議的工作原理?
20. TCP 的主要特點(diǎn)是什么?
21. UDP 的主要特點(diǎn)是什么?
22. TCP 和 UDP 分別對(duì)應(yīng)的常見應(yīng)用層協(xié)議有哪些?
23. 為什么 TIME-WAIT 狀態(tài)必須等待 2MSL 的時(shí)間呢?
24. 保活計(jì)時(shí)器的作用?
25. TCP 協(xié)議是如何保證可靠傳輸?shù)模?/p>
26. 談?wù)勀銓?duì)停止等待協(xié)議的理解?
27. 談?wù)勀銓?duì) ARQ 協(xié)議的理解?
28. 談?wù)勀銓?duì)滑動(dòng)窗口的了解?
29. 談下你對(duì)流量控制的理解?
30. 談下你對(duì) TCP 擁塞控制的理解?使用了哪些算法?
31. 什么是粘包?
32. TCP 黏包是怎么產(chǎn)生的?
33. 怎么解決拆包和粘包?
34. forward 和 redirect 的區(qū)別?
35. HTTP 方法有哪些?
36. 在瀏覽器中輸入 URL 地址到顯示主頁(yè)的過(guò)程?
37. DNS 的解析過(guò)程?
38. 談?wù)勀銓?duì)域名緩存的了解?
39. 談下你對(duì) HTTP 長(zhǎng)連接和短連接的理解?分別應(yīng)用于哪些場(chǎng)景?
40. HTTPS 的工作過(guò)程?
41. HTTP 和 HTTPS 的區(qū)別?
42. HTTPS 的優(yōu)缺點(diǎn)?
43. 什么是數(shù)字簽名?
44. 什么是數(shù)字證書?
45. Cookie 和 Session 有什么區(qū)別?
十、操作系統(tǒng) 32 道
1. 簡(jiǎn)單說(shuō)下你對(duì)并發(fā)和并行的理解?
2. 同步、異步、阻塞、非阻塞的概念
3. 進(jìn)程和線程的基本概念
4. 進(jìn)程與線程的區(qū)別?
5. 為什么有了進(jìn)程,還要有線程呢?
6. 進(jìn)程的狀態(tài)轉(zhuǎn)換
7. 進(jìn)程間的通信方式有哪些?
8. 進(jìn)程的調(diào)度算法有哪些?
9. 什么是死鎖?
10. 產(chǎn)生死鎖的原因?
11. 死鎖產(chǎn)生的必要條件?
12. 解決死鎖的基本方法?
13. 怎么預(yù)防死鎖?
14. 怎么避免死鎖?
15. 怎么解除死鎖?
16. 什么是緩沖區(qū)溢出?有什么危害?
17. 分頁(yè)與分段的區(qū)別?
18. 物理地址、邏輯地址、虛擬內(nèi)存的概念
19. 頁(yè)面置換算法有哪些?
20. 談?wù)勀銓?duì)動(dòng)態(tài)鏈接庫(kù)和靜態(tài)鏈接庫(kù)的理解?
21. 外中斷和異常有什么區(qū)別?
22. 一個(gè)程序從開始運(yùn)行到結(jié)束的完整過(guò)程,你能說(shuō)出來(lái)多少?
23. 什么是用戶態(tài)和內(nèi)核態(tài)
24. 用戶態(tài)和內(nèi)核態(tài)是如何切換的?
25. 進(jìn)程終止的方式
26. 守護(hù)進(jìn)程、僵尸進(jìn)程和孤兒進(jìn)程
27. 如何避免僵尸進(jìn)程?
28. 介紹一下幾種典型的鎖?
29. 常見內(nèi)存分配內(nèi)存錯(cuò)誤
30. 內(nèi)存交換中,被換出的進(jìn)程保存在哪里?
31. 原子操作的是如何實(shí)現(xiàn)的
32. 抖動(dòng)你知道是什么嗎?它也叫顛簸現(xiàn)象
十一、消息隊(duì)列與分布式 26 道
1. 消息隊(duì)列的基本作用?
2. 消息隊(duì)列的優(yōu)缺點(diǎn)有哪些?
3. 如何保證消息隊(duì)列的高可用?
4. 如何保證消息不被重復(fù)消費(fèi)?或者說(shuō),如何保證消息消費(fèi)的冪等性?
5. 如何保證消息的可靠性傳輸?或者說(shuō),如何處理消息丟失的問題?
6. 如何保證消息的順序性?
7. 大量消息在 MQ 里長(zhǎng)時(shí)間積壓,該如何解決?
8. MQ 中的消息過(guò)期失效了怎么辦?
9. RabbitMQ 有哪些重要的角色?
10. RabbitMQ 有哪些重要的組件?
11. RabbitMQ 有幾種廣播類型?
12. Kafka 可以脫離 zookeeper 單獨(dú)使用嗎?為什么?
13. Kafka 有幾種數(shù)據(jù)保留的策略?
14. Kafka 的分區(qū)策略有哪些?
15. 談下你對(duì) Zookeeper 的認(rèn)識(shí)?
16. Zookeeper 都有哪些功能?
17. 談下你對(duì) ZAB 協(xié)議的了解?
18. Zookeeper 怎么保證主從節(jié)點(diǎn)的狀態(tài)同步?
19. Zookeeper 有幾種部署模式?
20. 說(shuō)一下 Zookeeper 的通知機(jī)制?
21. 集群中為什么要有主節(jié)點(diǎn)?
22. 集群中有 3 臺(tái)服務(wù)器,其中一個(gè)節(jié)點(diǎn)宕機(jī),這個(gè)時(shí)候 Zookeeper 還可以使用嗎?
23. 說(shuō)一下兩階段提交和三階段提交的過(guò)程?分別有什么問題?
24. Zookeeper 宕機(jī)如何處理?
25. 說(shuō)下四種類型的數(shù)據(jù)節(jié)點(diǎn) Znode?
26. Zookeeper 和 Dubbo 的關(guān)系?
由于篇幅有限,無(wú)法展示全部
需要的小伙伴
移步后臺(tái)打招呼即可
關(guān)鍵詞: