Java面试题!5年经验Java程序员面试27天,看看这篇文章吧!
Kafka宕機引發的高可用問題
問題要從一次Kafka的宕機開始說起。
筆者所在的是一家金融科技公司,但公司內部并沒有采用在金融支付領域更為流行的RabbitMQ,而是采用了設計之初就為日志處理而生的Kafka,所以我一直很好奇Kafka的高可用實現和保障。從Kafka部署后,系統內部使用的Kafka一直運行穩定,沒有出現不可用的情況。
但最近系統測試人員常反饋偶有Kafka消費者收不到消息的情況,登陸管理界面發現三個節點中有一個節點宕機掛掉了。但是按照高可用的理念,三個節點還有兩個節點可用怎么就引起了整個集群的消費者都接收不到消息呢?
要解決這個問題,就要從Kafka的高可用實現開始講起。
面試準備
不論是校招還是社招都避免不了各種面試、筆試,如何去準備這些東西就顯得格外重要。 運籌帷幄之后,決勝千里之外!不打毫無準備的仗,我覺得大家可以先從下面幾個方面來準備面試:
1. 自我介紹。(介紹自己的項目經歷以及一些特長而不是簡單自我介紹喜好等)
2. 自己面試中可能涉及哪些知識點、那些知識點是重點。
3. 面試中哪些問題會被經常問到、面試中自己該如何回答。
4. 自己的簡歷該如何寫。
“80%的o?er掌握在20%的人手中” 這句話也不是不無道理的。決定你面試能否成功的因素中實力固然占有很大一部 分比例,但是如果你的心態或者說運氣不好的話,依然無法拿到滿意的 o?er。運氣暫且不談,就拿心態來說,千萬 不要因為面試失敗而氣餒或者說懷疑自己的能力,面試失敗之后多總結一下失敗的原因,后面你就會發現自己會越來 越強大。
另外,大家要明確的很重要的幾點是:
1. 寫在簡歷上的東西一定要慎重,這可能是面試官大量提問的地方;
2. 將自己的項目經歷完美的展示出來非常重要。
常見面試問題及范圍如下
Java基礎
重載和重寫的區別
String 和 StringBuffer、StringBuilder 的區別是什么?String 為什么是不可變的?
自動裝箱與拆箱
== 與 equals
final 關鍵字
Object類的常見方法
Java 中的異常處理
獲取用鍵盤輸入常用的的兩種方法
接口和抽象類的區別是什么
集合框架
Arraylist 與 LinkedList 異同
ArrayList 與 Vector 區別
HashMap的底層實現
HashMap 和 Hashtable 的區別
HashMap 的長度為什么是2的冪次方
HashMap 多線程操作導致死循環問題
HashSet 和 HashMap 區別
ConcurrentHashMap 和 Hashtable 的區別
ConcurrentHashMap線程安全的具體實現方式/底層具體實現
多線程與并發
AQS 原理
AQS 對資源的共享方式
AQS底層使用了模板方法模式
說一說自己對于 synchronized 關鍵字的了解
說說自己是怎么使用 synchronized 關鍵字,在項目中用到了嗎
講一下 synchronized 關鍵字的底層原理
說說 JDK1.6 之后的synchronized 關鍵字底層做了哪些優化,可以詳細介紹一下這些優化嗎
談談 synchronized和ReenTrantLock 的區別
說說 synchronized 關鍵字和 volatile 關鍵字的區別
為什么要用線程池?
實現Runnable接口和Callable接口的區別
執行execute()方法和submit()方法的區別是什么呢?
如何創建線程池
介紹一下Atomic 原子類
JUC 包中的原子類是哪4類?
講講 AtomicInteger 的使用
能不能給我簡單介紹一下 AtomicInteger 類的原理
JVM
Java 中會存在內存泄漏嗎,簡述一下?
描述一下 JVM 加載 Class 文件的原理機制?
什么是tomcat類加載機制?
類加載器雙親委派模型機制?
垃圾回收常見問題
什么是GC? 為什么要有 GC?
簡述一下Java 垃圾回收機制?
如何判斷一個對象是否存活?
垃圾回收的優點和原理,并考慮 2 種回收機制?
Java 中垃圾收集的方法有哪些?
講講你理解的性能評價及測試指標?
常用的性能優化方式有哪些?
網絡編程與操作系統
TCP、UDP 協議的區別
在瀏覽器中輸入url地址 ->> 顯示主頁的過程
各種協議與HTTP協議之間的關系
HTTP長連接、短連接
TCP 三次握手和四次揮手(面試常客)
簡單介紹一下 Linux 文件系統?
一些常見的 Linux 命令了解嗎?
MySQL
說說自己對于 MySQL 常見的兩種存儲引擎:MyISAM與InnoDB的理解?
數據庫索引了解嗎?
為什么索引能提高查詢速度?
Mysql如何為表字段添加索引?
對于大表的常見優化手段說一下?
Spring
Spring Bean 的作用域
Spring 事務中的隔離級別
Spring 事務中的事務傳播行為
AOP是什么?
IOC是什么?
分布式
為什么要用 redis緩存?
為什么要用 redis 而不用 map/guava 做緩存?
redis 和 memcached 的區別?
redis 常見數據結構以及使用場景分析?(String,Hash,List,Set,Sorted Set)
redis 設置過期時間
redis 內存淘汰機制(MySQL里有2000w數據,Redis中只存20w的數據,如何保證Redis中的數據都是熱點數據?)
redis 持久化機制(怎么保證 redis 掛掉之后再重啟數據可以進行恢復)?
redis 事務
緩存雪崩和緩存穿透問題解決方案
如何解決 Redis 的并發競爭 Key 問題
如何保證緩存與數據庫雙寫時的數據一致性?
什么是消息隊列?為什么要用消息隊列?
通過異步處理提高系統性能(削峰、減少響應所需時間)
降低系統耦合性
使用消息隊列帶來的一些問題
JMS兩種消息模型
JMS 五種不同的消息正文格式
常見的消息隊列對比
什么是 Dubbo?為什么要用 Dubbo?
什么是 RPC?RPC原理是什么?
Dubbo 工作原理?
解釋一下什么是負載均衡?
看看 Dubbo 提供的負載均衡策略?
zookeeper宕機與dubbo直連的情況?
總結
總體來說,如果你想轉行從事程序員的工作,Java開發一定可以作為你的第一選擇。但是不管你選擇什么編程語言,提升自己的硬件實力才是拿高薪的唯一手段。
如果你以這份學習路線來學習,你會有一個比較系統化的知識網絡,也不至于把知識學習得很零散。我個人是完全不建議剛開始就看《Java編程思想》、《Java核心技術》這些書籍,看完你肯定會放棄學習。建議可以看一些視頻來學習,當自己能上手再買這些書看又是非常有收獲的事了。
這些視頻如果需要的話,可以無償分享給大家,點擊這里即可免費領取
件實力才是拿高薪的唯一手段。
如果你以這份學習路線來學習,你會有一個比較系統化的知識網絡,也不至于把知識學習得很零散。我個人是完全不建議剛開始就看《Java編程思想》、《Java核心技術》這些書籍,看完你肯定會放棄學習。建議可以看一些視頻來學習,當自己能上手再買這些書看又是非常有收獲的事了。
這些視頻如果需要的話,可以無償分享給大家,點擊這里即可免費領取
總結
以上是生活随笔為你收集整理的Java面试题!5年经验Java程序员面试27天,看看这篇文章吧!的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: cutftp.exe
- 下一篇: 面试2年经验的Java程序员面试题部分带