學習路線圖每每是學習同樣技術的入門指南。網上搜到的Java學習路線圖也是一抓一大把。linux
今天我只選一張圖,僅此一圖,足以包羅Java後端技術的知識點。所謂不求最好,但求最全,學習Java後端的同窗徹底能夠參考這張圖進行學習路線安排。程序員
固然,有一些知識點是可選的,並非說上面有的你都要會啦。我在複習秋招的過程當中就是基於此圖進行復習的,感受效果仍是不錯的。web
閒言少敘,咱們仍是看看這張圖上都包含哪些有價值的信息吧。再次說明,本文只對路線圖作一個簡單地解讀,僅供參考。你們能夠根據自身狀況來指定合理的學習計劃,相信也會大有裨益。面試
這部份內容是計算機相關專業同窗的課程,可是非科班的小夥伴(譬如在下)就須要花時間惡補了。特別是計算機網絡,操做系統,數據結構這三門課程。算法
至於編譯原理,我的大概懂一點就好了,我也只看過簡單的概念和狀態機相關的內容,並非特別重要。sql
這裏的Java編程部分包含了不少內容。咱們能夠分別看看,大概概括一下就是這幾個部分。docker
這裏的Java基礎包括基本語法,集合類框架,以及一些高級特性,好比反射,註解等等。shell
Java基礎的知識點很是多,因此要真正搞懂也沒有那麼簡單,另外,隨着時間推移,一些新特性也須要獲得咱們的重視,好比時下流行的JDK8。數據庫
我一直以爲設計模式能夠和Java基礎一塊學,因此我也把它放在這裏。固然,一些真正使用到設計模式的地方,譬如JDK的集合類,IO流等等,也須要你足夠重視。編程
Java Web技術包括J2EE,以及web框架,乃至一系列經常使用的組件。
1 J2EE主要包括的就是servlet,jsp這些比較復古的web開發組件了。雖然如今直接用它們的狀況比較少,可是咱們仍是須要花一些時間去掌握它們的。
2 web框架經常使用的就是Spring了,相應的,hibernate和mybatis也須要了解一下。
3 同時,JavaWeb開發時的經常使用類庫,好比jnuit單元測試,log4j日誌工具,以及構建工具maven,都屬於咱們要掌握的範疇。
4 最後,要注意的是,Web相關的一些基本知識,好比HTTP協議,網絡安全基礎,也是咱們要考慮的部分。
Java的併發技術泛指Java的多線程技術,以及JUC包裏的併發類,好比線程池,併發工具類,阻塞隊列等等。
Java併發技術徹底能夠獨立出來學習,是Java進階知識的一大重點。
這一塊內容是Java中比較複雜但也很重要的一塊內容。好比BIO,NIO,AIO的一些使用和原理,以及tomcat這類web服務器,甚至是netty這種網絡編程框架,都是能夠去了解和學習的內容。
JVM是提供Java程序運行的一個進程,學習JVM知識,也是咱們的必經之路。除了看懂《深刻理解jvm虛擬機》之外,咱們還要學習的內容就是JVM調優,使用合適的工具診斷問題,最後解決問題。
這部份內容在面試中呈現的不只僅是GC,內存分區,以及類加載器,也包括了我所說的JVM調優問題。
做爲後臺同窗,常年被面試官問linux相關的問題,因此以爲學好linux仍是蠻重要的,除了基本命令之外,最好還能瞭解一些shell腳本,甚至是內核相關的知識,這方面是個人一個弱項。
在這個路線圖裏,數據部分囊括了很是多的數據源,咱們能夠來看看都有哪些是咱們須要掌握的。
這個沒必要多說,人手都要會,不論是基礎的crud,索引,抑或是進階的存儲引擎,分佈式方案等,咱們都須要對應掌握。
如Redis,memcache一類的緩存,做爲後端開發者的咱們也須要對應掌握,固然,它們的高級特性,以及分佈式方案,也是必備的知識點。
基於Lucene的solr,elasticsearch這類搜索引擎,本質上也是數據源,可是並非後端必備的內容,不過學一學也沒有壞處啦。
海量數據處理的場景愈來愈多,大數據技術如hadoop,storm等也愈來愈火,可是大數據應用通常會由專業的大數據工程師來作,因此咱們學一些基本內容也就足夠了。
算法一直是校招同窗面前的一座大山,做爲後端同窗來說,除了基本的數據結構算法之外,也要會一些高級的算法,譬如dp,搜索,貪心等等。
另外,經過LeetCode等題庫來刷題的方式來鞏固算法也是公認的好辦法了。
最後一個部分,也是內容最多,覆蓋面最普遍的部分了。分佈式相關的技術實在太多了,咱們這裏也會作一下簡單的概括。
先了解web架構的發展會對分佈式的學習有更好的理解,畢竟架構的發展也對應着分佈式技術的發展。
這部份內容包括分佈式的發展演化,base理論和cap理論等等,學習分佈式技術以前,最好能對這部分概念有必定了解。
強一致性的解決方案:事務和鎖,弱一致性的方案:消息隊列。
一個常見的問題,也有多種解決方案
和上面說的緩存同樣,只不過這裏側重緩存的分佈式方案
這裏指的數據庫的分佈式方案,也包括hbase這種分佈式數據庫。
負載均衡也是一個值得探討的話題,通常咱們討論的是七層和四層負載均衡。
消息隊列是一個比較複雜的分佈式組件,咱們能夠了解經常使用消息隊列好比amq,kafka等的實現。
服務化的核心包括rpc,服務註冊中心等等。分佈式服務相關技術也是後端同窗必須掌握的內容。
虛擬化一樣不是後端同窗必須掌握的內容,只不過如今愈來愈多的服務部署方式使用的是docker和雲服務的方式。因此瞭解一下也沒有什麼很差的。
微信公衆號【程序員江湖】
做者黃小斜,斜槓青年,某985碩士,阿里研發工程師,於2018 年秋招拿到 BAT 頭條、網易、滴滴等 8 個大廠 offer
我的擅長領域 :自學編程、技術校園招聘、軟件工程考研(關注公衆號後回覆」資料「便可領取 3T 免費技術學習資源)