1. 程式人生 > >Java程序員如何從碼農晉升為架構師,你跟架構師的差別在哪裏?

Java程序員如何從碼農晉升為架構師,你跟架構師的差別在哪裏?

分布式緩存技術 需要 應用 快速查找 面向對象 但是 linux 有效 免費

一、如何定義架構師

Java架構師,首先要是一個Java程序員,熟練使用各種框架,並知道它們實現的原理。jvm虛擬機原理、調優,懂得jvm能讓你寫出性能更好的代碼;池技術,什麽對象池,怎麽解決並發量、連接池,線程池。

Java反射技術,寫框架必備的技術,但是有嚴重的性能問題,替代方案Java字節碼技術;nio,沒什麽好說的,值得註意的是”直接內存”的特點,使用場景;java多線程同步異步;java各種集合對象的實現原理,了解這些可以讓你在解決問題時選擇合適的數據結構,高效的解決問題,比如hashmap的實現原理,好多五年以上經驗的人都弄不清楚,還有為什擴容時有性能問題?不弄清楚這些原理,就寫不出高效的代碼,還會認為自己做的很對;總之一句話越基礎的東西越重要,很多人認為自己會用它們寫代碼了,其實僅僅是知道如何調用api而已,離會用還差的遠。

熟練使用各種數據結構和算法,數組、哈希、鏈表、排序樹…,一句話要麽是時間換空間要麽是空間換時間,這裏展開可以說一大堆,需要有一定的應用經驗,用於解決各種性能或業務上的問題。

二、技術歸納

熟練使用linux操作系統,必備,沒什麽好說的 。

熟悉tcp協議,創建連接三次握手和斷開連接四次握手的整個過程,不了解的話,無法對高並發網絡應用做優化; 熟悉http協議,尤其是http頭,我發現好多工作五年以上的都弄不清session和cookie的生命周期以及它們之間的關聯。

系統集群、負載均衡、反向代理、動靜分離,網站靜態化 。

分布式存儲系統nfs,fastdfs,tfs,Hadoop了解他們的優缺點,適用場景 。

分布式緩存技術memcached,redis,提高系統性能必備,一句話,把硬盤上的內容放到內存裏來提速,順便提個算法一致性hash 。

工具nginx必備技能超級好用,高性能,基本不會掛掉的服務器,功能多多,解決各種問題。

數據庫的設計能力,mysql必備,最基礎的數據庫工具,免費好用,對它基本的參數優化,慢查詢日誌分析,主從復制的配置,至少要成為半個mysql dba。其他nosql數據庫如mongodb。

還有隊列中間件。如消息推送,可以先把消息寫入數據庫,推送放隊列服務器上,由推送服務器去隊列獲取處理,這樣就可以將消息放數據庫和隊列裏後直接給用戶反饋,推送過程則由推送服務器和隊列服務器完成,好處異步處理、緩解服務器壓力,解藕系統。

三、面試方面

企業應用的系統架構師應該關註的幾個方面 (具體情況具體分析,以下未必準確,只是參考)

先來一些基礎面試題,您答得出麽?

1、說說JVM原理?內存泄露與溢出區別,何時產生內存泄露?

2、用java怎麽實現有每天有1億條記錄的DB存儲?mysql上億記錄數據量的數據庫如何設計?

3、mysql支持事務嗎?DB存儲引擎有哪些?

4、mvc原理,mvc模式的優缺點,如果讓你設計你會怎麽改造MVC?

5、hibernate支持集群嗎?如何實現集群?

6、tomcat 最多支持並發多少用戶?

7、map原理,它是如何快速查找key的?map與set區別?

8、描術算法,如何有效合並兩個文件:一個是1億條的用戶基本信息,另一個是用戶每天看電影連續劇等的記錄,5000萬條。內存只有1G???

9、在1億條用戶記錄裏,如何快速查詢統計出看了5個電影以上的用戶? ----可以參考 位圖索引的原理

10、Spring如何實現IOC與AOP的,說出實現原理?

以上純粹是常用的技術,還有很多自己慢慢去摸索吧;因為要知道的東西很多,所以要成為一名合格的架構師,必須要有強大的自學能力,沒有人會手把手的教給你所有的東西。

想成為架構師不是懂了一大堆技術就可以了,這些是解決問題的基礎、是工具,不懂這些怎麽去提解決方案呢?這是成為架構師的必要條件。

架構師要針對業務特點、系統的性能要求提出能解決問題成本最低的設計方案才合格,人家一個幾百人用戶的系統,訪問量不大,數據量小,你給人家上集群、上分布式存儲、上高端服務器,為了架構而架構,這是最扯淡的,架構師的作用就是第一滿足業務需求,第二最低的硬件網絡成本和技術維護成本。

架構師還要根據業務發展階段,提前預見發展到下一個階段系統架構的解決方案,並且設計當前架構時將架構的升級擴展考慮進去,做到易於升級;否則等系統瓶頸來了,出問題了再去出方案,或現有架構無法擴展直接扔掉重做,或擴展麻煩問題一大堆,這會對企業造成損失。

在此跟大家分享一份工作2-5年的Java程序員學習路線圖:

技術分享圖片

技術分享圖片

技術分享圖片

再給往架構師方面發展的朋友推薦幾本書

Java系統架構師應該看的幾本書

Thinking in Java

Effective Java

UML基礎、案例與應用

UML入門提高

軟件工匠

設計模式——可復用面向對象軟件的基礎

重構-改善既有代碼的設計

敏捷軟件開發-原則、模式、實踐

企業應用架構模式

Expert One-on-One J2EE Development without EJB

軟件工程——實踐者的研究方法

軟件領導,成功開發軟件的指導準則

後面的兩本書,其實已經有點屬於項目經理的範疇了,不過還不是很深入,看看對做成功的系統架構師是很有好處。

總結:其實架構師定義是模棱兩可的,有些7、8年開發人員也算不上架構師,架構師一般是在某領域超乎常人的理解,在公司遇到技術方面難題的時候,這個時候如果你技術過硬,能快速的解決問題。

Java程序員如何從碼農晉升為架構師,你跟架構師的差別在哪裏?