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