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