前言
一門“永不過時”的編程語言—Java,為什么說Java是“永不過時”呢?雖然這幾年Java的編程界龍頭的位置被Python,C超越過,但是隨著5G時代的到來,萬物互聯,更多的終端會使用安卓系統,所以未來5年甚至10年Java開發必然是會越來越火爆的,下面就是我總結的2021最全最新的Java后端學習路線,
附圖(簡略版):

詳述
計算機基礎知識
學習Java之前最好要了解一些計算機基礎知識,這樣會使你學起來更輕松一點,例如計算機硬體的組成及各組成部分的功能、進制知識、作業系統、網路、行程、執行緒、Linux常用命令等,這些雖然是基礎,但是都很重要,幾乎都是會伴隨你整個編程生涯,俗話說“墻高基下,雖得必失”,所以打好基礎是很重要的,
Java基礎知識
當我們掌握一定的計算機基礎知識之后,學習Java就不會太難,例如語言基礎、多執行緒、JVM(Java虛擬機)、Java的面向物件思想和常用基礎類、集合、IO流、多執行緒、例外、反射等,這些基礎的東西才是中最難的,當你把這些基礎性的東西搞的很透徹,那么你以后的學習生涯幾乎不會遇到什么大的問題,
常用工具
我們學習Java會使用到很多工具,我來介紹一下我們最常用的一些工具,例如IDEA、Eclipse、Git、SVN、Mavan、Gradle、JMC、VSCode、PostMan、Google Chrome、PDMan、Linux問題分析工具等,
IDEA
IDEA是公認為最好的Java開發工具,尤其在智能代碼助手、代碼自動提示、重構、JavaEE支持、各類版本工具(git、svn等)、JUnit、CVS整合、代碼分析、 創新的GUI設計等方面的功能可以說是超常的,
Eclipse
Eclipse是著名的跨平臺的自由集成開發環境(IDE),最初主要用來Java語言開發,但是現在有人通過插件使其作為其他計算機語言比如C++和Python的開發工具,
Git
Git 是一個開源的分布式版本控制系統,用于敏捷、有效、高速的處理任何很小或很大的專案,
Git 與常用的版本控制工具 CVS, Subversion 等不同,它采用了分布式版本庫的方式,不必服務器端軟體支持,
SVN
SVN是subversion的縮寫,是一個開放源代碼的版本控制系統,通過采用分支管理系統的高效管理,簡而言之就是用于多個人共同開發同一個專案,實作共享資源,實作最終集中式的管理,但是SVN必須在有網路的情況下才能提交代碼而Git并不需要,
Mavan
Maven是 Apache 下的一個純 Java 開發的開源專案,基于專案物件模型(縮寫:POM)概念,Maven利用一個中央資訊片斷能管理一個專案的構建、報告和檔案等步驟,
Maven 是一個專案管理工具,可以對 Java 專案進行構建、依賴管理,
Maven 也可被用于構建和管理各種專案,例如 C#,Ruby,Scala 和其他語言撰寫的專案
<dependencies>
<!-- 在這里添加你的依賴 -->
<dependency>
<groupId>com.mc</groupId> <!-- 包路徑,也可以自定義 -->
<artifactId>mc-utils</artifactId> <!--庫名稱,也可以自定義-->
<version>1.0</version> <!--版本號-->
<scope>system</scope> <!--作用域-->
<systemPath>${basedir}\src\lib\ldapjdk.jar</systemPath> <!--專案根目錄下的lib檔案夾下-->
</dependency>
</dependencies>
JMC
JMC是源自JRockit JVM的一套監控和管理工具,Oracle在發布JAVA 7u4(Java 7 Update 40)時將其包含在JDK中,用戶不再需要單獨下載,
使用 JMC可以監視和管理 Java 應用程式,不會導致相關工具類的大幅度性能開銷,它使用為 Java 虛擬機 (JVM) 的普通自適應動態優化收集的資料,
VS Code
是Microsoft在2015年4月30日Build開發者大會上正式宣布一個運行于 Mac OS X、Windows和 Linux 之上的,針對于撰寫現代Web和云應用的跨平臺源代碼編輯器 可在桌面上運行,并且可用于Windows,macOS和Linux,它具有對JavaScript,TypeScript和Node.js的內置支持,并具有豐富的其他語言(例如C++,C#,Java,Python,PHP,Go)和運行時(例如.NET和Unity)擴展的生態系統(摘自百度百科)
PostMan
在我們平時開發中,特別是需要與介面打交道時,無論是寫介面還是用介面,拿到介面后肯定都得提前測驗一下,這樣的話就非常需要有一個比較給力的Http請求模擬工具,現在流行的這種工具也挺多的,像火狐瀏覽器插件-RESTClient,Chrome瀏覽器插件-Postman等等,這里介紹的Postman并不是Chrome瀏覽器插件,因為2018年初Chrome停止對Chrome應用程式的支持,Postman提供了獨立的安裝包,不再依賴于Chrome瀏覽器了,同時支持MAC、Windows和Linux,
PDMan
PDMan是一款開源免費的資料庫模型建模工具,支持Windows,Mac,Linux等作業系統,支持常見資料庫MySQL,Oracle,SQLServer,DB2等,PDMan是PowerDesigner之外,另一個更好的免費的替代方案,他具有顏值高,使用簡單的特點,包含資料庫建模,靈活自動的自動生成代碼模板,自動生成檔案,自動同步DDL腳本到資料庫,資料模型版本管理等多種開發人員實用的功能,
前端
雖然我們是后端,但是我們可不能閉門造車,我們后端也是要學一些前端知識的,HTML、CSS、JS、Ajax我覺得是必須掌握的點,這些看著簡單,但是如果深究的話,還是有很多點的,
還有市面上比較火的的前端三大框架Angular、React、Vue,這些東西入門很簡單,我們后端的話,只要會用其實就夠了,不用深究其中的原理,
對我來說,前端總結起來就是一句話,入門簡單,精通很難,
資料庫
資料庫是資料的倉庫,
與普通的“資料倉庫”不同的是,資料庫依據“資料結構”來組織資料,因為“資料結構”,所以我們看到的資料是比較“條理化”的(比如不會跟以前的普通檔案存盤式存盤成一個檔案那么不條理化,我們的資料庫分成一個個庫,分成一個個表,分成一條條記錄,這些記錄多么分明)
資料庫分為關系型資料庫和非關系型資料庫,關系型資料庫的是以表格形式存盤的,非關系型資料不適合存盤在資料表的行和列中,而是大塊組合在一起,非關系型資料通常存盤在資料集中,就像檔案、鍵值對或者圖結構
主流的關系型資料庫:Mysql、Oracle、DB2、PostgreSQL、SQL Server
主流的非關系型資料庫:Redis、MemcacheDB、MongoDB
快取中間件
在計算中,快取是一個高速存盤層,其中存盤了資料子集,且通常是短暫性存盤,這樣日后再次請求此資料時,速度要比訪問資料的主存盤位置快,通過快取,可以高效地重用之前的檢索或計算的資料,
MemCached
MemCached是一種基于記憶體的key-value存盤,用來存盤小塊的任意資料(字串、物件),它便于快速開發,減輕開發難度,解決了大資料量快取的很多問題,本質上,它是一個簡潔的key-value存盤系統
Redis
Redis 是完全開源免費的,是一個高性能的key-value資料庫,Redis與其他key - value 快取產品對比有著一些優勢,Redis支持資料持久化,將記憶體中的資料保存在磁盤中,重啟的時候可以再次加載出來,
Redis支持多種資料結構的存盤,Redis支持資料備份,
基本框架
Java后端一些必須的框架,Spring、Spring MVC、Mybatis、Mybatis Plus、Spring Boot,這些是最基本的框架,空余時間還可以學習分布式框架,NIO框架等等
網關
網關就是對請求到我們系統的所有請求做一個攔截,對這些請求做一些處理,最后找到對應的路由去請求,
問題1:
單機頂不住,我們多加幾臺服務器做集群,但是怎么將流量均勻的發到這些服務器上呢?
負載均衡,LVS
問題2:
我們機器都是通過IP訪問的,那怎么通過我們申請的域名去請求到服務器呢?:
DNS
問題3:
大家平時刷的短視頻平臺,是怎么保證同時為全國的用戶提供快速的體驗?
CDN
問題4:
我們這么多服務和中間件,是怎么去管理調度的?
Zookeeper
問題5:
這么多的服務器,怎么對外統一訪問呢,就可能需要知道反向代理的服務器,
Nginx
訊息佇列
我們可以把訊息佇列比作是一個存放訊息的容器,當我們需要使用訊息的時候可以取出訊息供自己使用,訊息佇列是分布式系統中重要的組件,使用訊息佇列主要是為了通過異步處理提高系統性能和削峰、降低系統耦合性,目前使用較多的訊息佇列有ActiveMQ,RabbitMQ,Kafka,RocketMQ,
總結起來就是一句話,訊息佇列主要是做異步、解耦、消峰的
搜索引擎
搜索引擎是一個幫助用戶搜索他們需要內容的計算機程式,換一種說法,搜索引擎就是把計算機中存盤的資訊與用戶所需要的資訊(information need)相匹配,并把匹配的結果展示出來,
例如:張三想購買一個手機,他在某寶的搜索框中輸入 手機 ,然后點擊搜索按鈕,在他按下搜索按鈕的時候,就會根據 手機 兩個字去某寶的巨大的資料庫中搜索,然后拿到所有的關于手機的產品,展示給張三,
RPC
RPC(Remote Procedure Call)遠程程序呼叫,通俗來講就是,一個服務呼叫另一個服務提供的介面,
目前主流的RPC框架有,Dubbo、SpringCloud、Netty
容器
容器是一種沙盒技術,主要目的是為了將應用運行在其中,并與外界隔離,可以方便的將這個沙盒轉移到其他機器上,通俗點的理解就是一個裝應用軟體的箱子,箱子里面有軟體運行所需的依賴庫和配置,開發人員可以把這個箱子搬到任何機器上,且不影響里面軟體的運行,
目前主流的容器技術有,Docker、Kubernetes
大資料
大資料是指無法在一定時間范圍內用常規軟體工具進行捕捉、管理和處理的資料集合,大資料的五大特征:1、大量;2、高速;3、多樣;4、低價值密度;5、真實性,大資料最核心的價值就是在于對于海量資料進行存盤和分析
大資料技術:ODPS,Hadoop,Hive,Hbase,Cassandra,Flink,Spark
轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/261357.html
標籤:其他
