導航:首頁 > 萬維百科 > 大型分布式網站架構設計與實踐pdf

大型分布式網站架構設計與實踐pdf

發布時間:2020-10-09 17:04:36

1、Java分布式應用如何入門以及有哪些資料

提到java分布式首先要知道rmi,幾乎所有的分布式都是跟rmi相似的原理。

2、大型分布式網站架構設計與實踐 怎麼樣

大型分布式網站架構設計與實踐 這本書 的點評如下:
書中提到了很多大型分布式網站設計所必須的知識點,如soa、分布式系統的基礎設施,
系統穩定性設計,數據分析,系統穩定設計的章節寫的很有實踐性,
自檢腳本的編寫、日誌分析命令的妙用,互聯網安全方面之前講類似知識點的,
書中介紹的比較詳細,不錯
還有疑問請追問沒有疑問請採納。

3、大家有什麼java面試的有關的書籍推薦

書的話我不知道,不過應該是沒有的,面試知識點可以自己去網上找一找,有很多面試過的人分享的面試題。而且面試難易看公司和應聘崗位的,有的公司水平低或者崗位專業性要求不高,面試就容易,有的公司水平高專業要求高,那就面試難。我貼一下我找的一些面試知識點。
3.1.1 Java基礎
此時一般會問到一些Java的基礎知識,比如
l synchronized static修飾類和方法有什麼區別
l HashMap的原理,底層數據結構,rehash的過程,指針碰撞問題
l HashMap的線程安全問題,為什麼會產生這樣的線程安全問題
l ConcurrentHashMap的數據結構,底層原理,put和get是否線程安全
l Java IO的一些內容,包括NIO,BIO等
3.1.2 Java高級特性
此時問到的問題一般包含JVM,多線程的一些內容,這塊建議大家多看看源碼,大致如下:
l Java線程池的構造方法,裡面參數的含義,以及原理
l volatile和ThreadLocal解決了什麼問題
l CAS在Java中的具體實現
l Java虛擬機的構成,以及一個Java對象的生命周期,還有堆棧和方法區中存儲的內容
l JVM的GC過程,包括一些實際問題的分析,比如說明一個現象,讓你分析可能是什麼原因會導致這樣的問題,應該如何對JVM參數進行調優
l synchronized和Lock的區別,以及底層實現原理
l Full GC和Minor GC觸發的條件
l GC Roots的選擇
l jmap,jstat,jstack等的使用場景,MAT等
l ClassLoader的載入過程
l CountDownLatch、CyclicBarrier和Semaphore等
l Java 8 的新特性等
3.1.3 資料庫
這里的資料庫包含兩種,一種一般是MySQL,另外是NoSql資料庫,包括Redis、MongoDB等。一般會問的問題有:
l inner join和left join等的區別
l SQL調優,explain,profile等
l InnoDB和Myisam的區別
l ACID
l 資料庫的事務隔離級別,以及他們分別能解決什麼問題
l Redis的幾種數據結構
l Redis是單線程還是多線程
l Redis的持久化
l 悲觀鎖和樂觀鎖的含義
l 最左前綴索引,索引的數據結構,聚簇索引等(這塊還沒搞明白)
3.1.4 框架
3.1.4.1 Spring
因為spring是我們常用的框架,所以這塊的內容會問的比較多,也會比較細。
l Spring的兩大特性(IoC和AOP)
l Spring的bean的生命周期
l Spring是如何解決Bean的循環引用問題的
l AOP的兩種實現方式,以及兩者的區別(這里其實使用了動態代理,具體動態代理分為兩種,一種是JDK的動態代理,主要使用的是JDK的反射,還有一種是CGLib,兩者區別可以自己搜索,文章比較多)
l AOP一般的使用場景
l Spring的事務原理
3.1.4.2 MyBatis
這塊問到的比較簡單些:
l $和#的區別
l MyBatis和Hibernate的區別
l 源碼,一般問的比較少
3.1.4.3 Dubbo
因為平時自己用到了Dubbo,所以這塊會有問到:
l RPC的原理
l Dubbo是如何完成遠程調用的
l Dubbo如何進行調優
l Dubbo的通信協議
l Dubbo是如何實現負載均衡的
3.1.4.4 ZooKeeper
l ZK的使用場景
l ZK的選舉機制
l ZK的節點類型
l 一致性Hash原理
3.1.5 數據結構和演算法
這塊的內容是基礎,如果面試官懷疑你的能力,一般一會問到這部分內容,比如樹的遍歷、快速排序等。
3.1.6 linux
一般會問一些命令的使用,然後會舉一個實際的場景,讓你用命令去排查問題,這塊自己不是很熟,需要盡快加強。
3.1.7 綜合題
這塊的題目,面試官一般會問的比較深入。比如如何設計一個搶購系統,String轉Integer等,這部分需要考驗的就是一個人的臨場應變能力,以及在平時工作中系統設計能力的積累,以及考慮問題是否周到等。也有可能會對你簡歷上面寫的系統的設計進行詳細的詢問,所以在你寫簡歷的時候,千萬不能把自己不熟悉的內容寫上去,而且自己又講不清,這樣一般會被直接pass掉。
當然也會問一些常用的maven的命令,設計模式的題目(這部分問的比較多的就是單例模式)。

與大型分布式網站架構設計與實踐pdf相關的知識