你好,我是彤哥,技術公眾號 “彤哥讀源碼” 的運營者。
其實,我剛學習 Netty 的時候,也是很迷茫的,直到有一天,一個同事收到了阿里的 offer,他要去阿里做中臺了,臨走前他偷偷地告訴我,多看看 Netty,特別是源碼。
之后,我把市面上有關 Netty 的書籍和博客幾乎全部看了一遍,并跟著書中的示例邊看邊練,但是,最后,我發現,在 Netty 的知識方面,我只是從一個學徒變成了一個熟練工,對 Netty 的理解還是談不上有多深刻,因為很多書籍或者博客對 Netty 的講解都停留在使用的角度,對于核心知識和底層原理,講解得很少,或者說是很不全面。
所以,我決定自己動手,把 Netty 的源碼擼一遍,沒多久,我就發現,我不僅在 Netty 方面的知識飛速增長,對于 Java 底層的很多原理也理解得更透徹了,得益于此,我后面進入了國內某互聯網游戲公司擔任平臺架構的設計與實現?,F在,我在國內某互聯網大廠擔任中臺架構的設計與實現,這其中,Netty 對我的影響無疑是巨大的。
這是我自己學習 Netty 的經歷,現在,你可以想想你的情況。
-
是不是一直想學習 Java 網絡編程,卻不知道怎么入門?
-
是不是看完《Netty 實戰》,還是只會寫入門級的示例?
-
是不是學習其他開源框架,一深入到通信層就無所適從?
-
是不是面試過程中,提及 Netty,只能簡單地說說請求的執行流程?對于更底層的線程池、對象池、內存池卻一問三不知?
如果你是這種情況,其實你并不孤獨,這不是你一個人遇到的問題,在工作中,我喜歡與人交流,發現很多同學,不管新人,還是老人,對 Netty 的掌握都停留在表面。
還是上面那位牛人,他去阿里后,遇到的第一個挑戰是他的領導讓他一個星期內學習完 Dubbo,并做成 PPT 分享給全組人員,對于從來沒學習過 Dubbo 的他,你可能會說,這太難了,幾乎不可能完成。然而,他學習 Dubbo 只花了五天時間,并把底層通信研究得非常透徹,剩余兩天做成 PPT,匯報時,領導都驚訝于它能在短短一周對 Dubbo 有如此深入的理解。
我覺得這其中他對 Netty 的深入理解占了很大的比例。后面,他跟我說,其實,Java 領域學來學去就那么些東西,最重要的還是掌握底層核心知識,這些核心知識掌握了,學習其他東西真的能事半功倍,這也是他能快速學習并獲得成功的秘訣。
那么,作為 Java 開發者,應該掌握哪些底層核心知識呢?
無外乎就是反射、代理、多線程這些東西,當然,還有 NIO,那么,如何快速地學習并掌握這些知識呢?
我認為通過源碼是一種不錯的途徑,不管是 Java 本身的源碼,還是開源框架的源碼。
而 Netty 作為 Java 網絡編程領域的事實標準,無疑是最合適的。
通過上圖,可以看到,在 Java 中,很多大家熟悉的框架都在使用 Netty,而且,這些框架遍布 Java 的各個領域,包括但不僅限于大數據、RPC、消息隊列、搜索引擎、數據庫等。
所以,我想做一個關于 Netty 的課程,希望通過這個課程能夠讓你真正掌握到 Netty 的底層核心知識。
那么,我將怎么設計這個課程呢?
我根據自己學習和使用 Netty 的經驗,將整個課程分成六個模塊來講解:
基礎知識,介紹 Netty 的發展歷史,并學習 Java 網絡編程的基礎知識,打好基礎,方能事半功倍;
源碼剖析 —— 數據流向,從數據流向的角度剖析源碼,包含服務啟動、接收數據、關閉連接等,快速掌握 Netty 應用運行的基本流程,這一部分源碼可以使用泛讀的技巧,快速閱讀,了解大致流程;
源碼剖析 —— 核心知識,從核心知識的角度剖析源碼,包含內存池、對象池、線程池等,深入底層,掌握核心要點,這一部分源碼需要精讀,對每一個知識點死磕到底;
項目實戰,從軟件開發生命周期的角度,介紹如何使用 Netty 開發一個生產級的游戲項目;
實戰進階,對實戰項目進行不斷調優,使其更穩定、更快速、更安全、更可靠,并介紹如何快速排查生產問題;
課程總結,對整個課程做一個總結和回顧。
我很感激當年偷偷告訴我要看 Netty 的那位同事,那無疑是我人生中非常重要的轉折點。
沒有那位同事的悄悄話,可能就沒有今天的我,希望這個專欄也能成為你的人生的一個轉折點。
最后,我希望通過這個專欄,不僅能夠幫你學習到 Netty 的底層核心知識,更能加深對 Java 底層核心知識的理解,幫你拿下 Netty 這座城,度過職場和人生的重要時刻,come on!