前言
歡迎加入咱們。這是一份針對實習生/畢業生的服務端開發入門與進階指南。遇到問題及時問你的 mentor 或者直接問我。 建議: 前端
- 儘可能用google查找技術資料。
- 有問題在stackoverflow找找,大部分都已經有人回答。
- 多看官方的技術文檔。
- ibm developerworkers的文章質量總體上有保障。
- 平時花一些時間在github上閱讀優秀項目源碼。
入門(1-2 個月)
- 目標:參與簡單的項目開發。
- 技能:
- 掌握 Java。經典的《Java 核心技術:卷1 基礎知識》(或者《Java 編程思想》)必看,跳過其中的圖形和 applet 章節。習慣經過 Java API Doc。爲了保證代碼的質量,《Effective Java》、《Clean Code》和《重構》也須要至少通讀一遍。
- 熟悉 Linux 開發環境和 bash shell。Linux 是咱們的開發和部署環境,你最好儘快熟練它。Linux 的基本使用能夠經過《鳥哥的Linux私房菜:基礎學習篇(第三版)》學習,開發 bash shell 腳本能夠參考《Linux Shell腳本攻略》。
- 掌握開發工具
- 熟練使用一種 IDE。Intellij IDEA或者 Eclipse 均可以,推薦使用前者。至少熟悉經常使用的快捷鍵,會 debug(包括遠程 debug)項目。
- 熟悉一種編輯器。好比 Vim/Emacs,至少學會搜索/替換/代碼補全。
- 掌握 JDK 之外的經常使用類庫和工具包。JDK 原生 API 在不少場景下使用並不方便。你須要掌握社區貢獻的優秀類庫和工具包,好比 apache commons、google guava 等,具體能夠翻閱《技術選型手冊》的Utility 篇。
- 掌握 Web 開發框架。咱們使用 Spring(或Rose) + Ibatis(或Jade) 開發 web 服務,你須要熟練掌握它們。
- 學習代碼規範。咱們大體上遵循 oracle 的 Java 語言編碼規範,你能夠先閱讀並熟悉它。Code Formatting 文件在 git@git.x.xx.com:xiaomi-commons/coding-standard.git,在編寫代碼以前,請把它導入到 IDE 中。另外,確認 IDE 已經安裝 Findbugs 和 CheckStyle 插件。
- 熟悉開發流程。咱們的開發流程大體以下:功能開發->單元測試->功能測試->Code Review->集成測試->發佈。確保你熟悉其中的每一個環節。
- 其餘。須要熟練使用版本控制工具 Git(閱讀:《Git 權威指南》),以及項目構建工具 Maven(閱讀:《Maven實戰》)。另外,在這個階段能夠嘗試 TDD 開發。
進階(2-6 個月)
- 目標:獨立負責某個服務端項目。
- 技能:
- 掌握 web 開發最佳實踐,掌握 Restful API 設計,理解 Spring 原理。推薦閱讀《Spring 揭祕》。掌握項目分層、子模塊劃分。推薦閱讀:《J2EE 核心模式》。
- 掌握 web 架構設計。包括 Http 反向代理,數據緩存,負載均衡,水平擴展和垂直擴展。推薦閱讀:《分佈式Java應用:基礎與實踐》。
- 掌握關係型數據庫。包括設計 MySQL 表結構,根據業務特色分表分庫,基於執行計劃的 SQL 分析優化,以及數據庫容量規劃。推薦閱讀:《MySQL 必知必會》、《高性能 MySQL》。
- 瞭解 NoSQL。咱們大規模使用 Hadoop、HBase、Hive,同時部分項目使用 Redis、Storm。你須要學會這些工具最基本的使用。
- 學習 web 安全知識。瞭解 web 前端安全問題。設計安全 web 服務,包括加解密、防僞造、防重放攻擊等。
- 掌握 Http(推薦閱讀:《圖解 Http》、《Http 權威指南》)、Thrift 等協議。
- 掌握服務容量規劃,性能調優,可靠性保證,以及故障處理。學習容量規劃和性能調優知識,梳理業務監控點,熟練使用咱們的監控報警系統。推薦閱讀:《深刻理解 Java 虛擬機》。
- 其餘。設計模式:從項目中學習,有時間能夠看看《深刻淺出設計模式》、《JDK 裏的設計模式》。學習Java Socket 編程與多線程知識,能夠看看《Java 併發編程實戰》,並翻翻併發編程網的文章。
深刻(6 個月-)
- 目標:分佈式系統和中間件開發。
- 構建知識體系:《大型網站系統與 Java 中間件實踐》、《大型網站技術架構:核心原理與案例分析》。
- 原理與設計:《大規模存儲式系統》、《UNIX 網絡編程 卷1:套接字聯網 API》、《How Tomcat Works》。
- 學習開源項目:Apache Thrift、Zipkin、Netty、Rose、Jade、淘寶 RPC 系統 Dubbo 等。分析項目中的設計思路。好比,一樣是RPC框架,Finagle 和 Dubbo 有什麼異同。
- 其餘。根據參與的項目加深學習吧。好比,若是須要寫 DSL,能夠讀一下《領域特定語言》,對 Redis 感興趣推薦讀一下:《Redis 設計與實現》。有兩本書,不管作什麼項目,都推薦讀:《Unix 編程藝術》、《UNIX 環境高級編程(第3版)》。