好老的文章了,今天把它挖出來了,其實在整個JAVA的學習中偶然性很多,改變你路線的東西也很多,很多東西是跟著工作的變化而變化的,因此關鍵在于把其中幾個學精通,有個主方向,并要懂靈活變化。真個技術生涯還包括架構、做人、團隊合作、管人、不斷學習新技術,等
第一階段
2.你需要學習JAVA語言的基礎知識以及它的核心類庫 (collections,serialization,streams,networking, multithreading,reflection,event,handling,NIO,localization,以及其他)。
5.你需要學習java數據庫技術,如JDBCAPI并且會使用至少一種persistence/ORM構架,例如Hibernate,JDO, CocoBase,TopLink,InsideLiberator(國產JDO紅工廠軟件)或者iBatis。
24.你應該熟練掌握一種JAVAIDE例如sunOne,netBeans,IntelliJIDEA或者Eclipse。(有些人更喜歡VI或EMACS來編寫文件。隨便你用什么了:)
26.你需要熟悉一種單元測試體系(JNunit),并且學習不同的生成、部署工具(Ant,Maven)。
27.你需要熟悉一些在JAVA開發中經常用到的軟件工程過程。例如RUP(RationalUnifiedProcess)andAgilemethodologies。
第二階段
1.你需要精通面向對象分析與設計(OOA/OOD)、涉及模式(GOF,J2EEDP)以及綜合模式。你應該十分了解UML,尤其是class,object,interaction以及statediagrams。
3.你應該了解JVM,classloaders,classreflect,以及垃圾回收的基本工作機制等。你應該有能力反編譯一個類文件并且明白一些基本的匯編指令。
6.你還應該了解對象關系的阻抗失配的含義,以及它是如何影響業務對象的與關系型數據庫的交互,和它的運行結果,還需要掌握不同的數據庫產品運用,比如:oracle,mysql,mssqlserver。
7.你需要學習JAVA的沙盒安全模式(classloaders,bytecodeverification,managers,policyandpermissions,
codesigning, digitalsignatures,cryptography,certification,Kerberos,以及其他)還有不同的安全/認證 API,例如JAAS(JavaAuthenticationandAuthorizationService),JCE (JavaCryptographyExtension),JSSE(JavaSecureSocketExtension),以及JGSS (JavaGeneralSecurityService)。
第三階段
10.你需要學習如何使用及管理WEB服務器,例如tomcat,resin,Jrun,并且知道如何在其基礎上擴展和維護WEB程序。
8.你需要學習Servlets,JSP,以及JSTL(StandardTagLibraries)和可以選擇的第三方TagLibraries。
4.如果你將要 寫客戶端程序,你需要學習WEB的小應用程序(applet),必需掌握GUI設計的思想和方法,以及桌面程序的SWING,AWT, SWT。你還應該對UI部件的JAVABEAN組件模式有所了解。JAVABEANS也被應用在JSP中以把業務邏輯從表現層中分離出來。(這條可有可 無)
9.你需要熟悉主流的網頁框架,例如JSF,Struts,Tapestry,Cocoon,WebWork,以及他們下面的涉及模式,如MVC/MODEL2。
14.你應該學習如何利用JAVAAPI和工具來構建WebService。例如JAX- RPC(JavaAPIforXML/RPC),SAAJ (SOAPwithAttachmentsAPIforJava),JAXB(JavaArchitectureforXMLBinding),JAXM(JavaAPIforXMLMessaging), JAXR(JavaAPIforXMLRegistries),或者JWSDP(JavaWebServicesDeveloperPack)。
15.你需要學習一門輕量級應用程序框架,例如Spring,PicoContainer,Avalon,以及它們的IoC/DI風格(setter,constructor,interfaceinjection)。
20.你需要熟悉對不同有用的API和frame work等來為你服務。例如Log4J(logging/tracing),Quartz (scheduling),JGroups(networkgroupcommunication),JCache(distributedcaching), Lucene(full-textsearch),JakartaCommons等等。
25.JAVA(精確的說是有些配置)是冗長的,它需要很多的人工代碼(例如EJB),所以你需要熟悉代碼生成工具,例如XDoclet
第四階段
16.你需要熟悉不同的J2EE技術,例如JNDI(JavaNamingandDirectoryInterface),JMS (JavaMessageService),JTA/JTS(JavaTransactionAPI /JavaTransactionService),JMX (JavaManagementeXtensions),以及JavaMail。
11.你需要學習分布式對象以及遠程API,例如RMI和RMI/IIOP。
12.你需要掌握各種流行中間件技術標準和與java結合實現,比如Tuxedo、CROBA,當然也包括javaEE本身。
17.你需要學習企業級JavaBeans(EJB)以及它們的不同組件模 式:Stateless/StatefulSessionBeans,EntityBeans(包含Bean- ManagedPersistence[BMP]或者Container-ManagedPersistence[CMP]和它的EJB-QL),或者 Message-DrivenBeans(MDB)。
13.你需要學習最少一種的XMLAPI,例如JAXP(JavaAPIforXMLProcessing),JDOM(JavaforXMLDocumentObjectModel),DOM4J,或JAXR(JavaAPIforXMLRegistries)。
18.你需要學習如何管理與配置一個J2EE應用程序服務器,如WebLogic,JBoss等,并且利用它的附加服務,例如簇類,連接池以及分布式處理支援。你還需要了解如何在它上面封裝和配置應用程序并且能夠監控、調整它的性能。
第五階段(優先級低)
19.你需要熟悉面向方面的程序設計以及面向屬性的程序設計(這兩個都被很容易混淆的縮寫為AOP),以及他們的主流JAVA規格和執行。例如AspectJ和AspectWerkz。
21.如果你將要對接或者正和舊的系統或者本地平臺,你需要學習JNI (JavaNativeInterface) and JCA (JavaConnectorArchitecture)。
22.你需要熟悉JINI技術以及與它相關的分布式系統,比如掌握CROBA。
23.你需要JavaCommunityProcess(JCP)以及他的不同JavaSpecificationRequests(JSRs),例如Portlets(168),JOLAP(69),DataMiningAPI(73),等等。
28.你需要能夠深入了解加熟練操作和配置不同的操作系統,比如GNU/linux,sunsolaris,macOS等,做為跨平臺軟件的開發者。
29.你還需要緊跟java發展的步伐,比如現在可以深入的學習javaME,以及各種java新規范,技術的運用,如新起的web富客戶端技術。
30.你必需要對opensource有所了解,因為至少java的很多技術直接是靠開源來驅動發展的,如java3D技術。
====================================================================
附:
JAVA系統架構師應該看的幾本書
Thinking in Java
Effective Java
UML基礎、案例與應用
UML入門提高
軟件工匠
設計模式——可復用面向對象軟件的基礎
重構-改善既有代碼的設計
敏捷軟件開發-原則、模式、實踐
企業應用架構模式
Expert One-on-One J2EE Development without EJB
軟件工程——實踐者的研究方法
軟件領導--成功開發軟件的指導準則
后面的兩本書,其實已經有點屬于項目經理的范疇了,不過還不是很深入,看看對做成功的系統架構師是很有好處。
企業應用的系統架構師應該關注的幾個方面 (具體情況具體分析,以下未必準確,只是參考)
先來一些基礎面試題,您答得出么?
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的,說出實現原理?
數據持久層的設計
在Spring和Hibernate,ibatis出來以前,幾乎每家公司都有自己的一套方法和架構,而架構師的50%的精力也會集中到這上面,EJB只是增加架構師的負擔。在Spring出來以后,基本上,大多數的架構師都從重復設計這個輪子的無用功中解脫出來了。Rod的輪子太好用了,基本上,大家只要套上去就行了,或者,剩下最重要的事情,是選擇一個合適的數據庫連接池的開源項目吧
MVC架構的具體設計
MVC只是個概要的概念,具體如何實現的具體技術很多,根據項目設計最恰當的架構
大并發性訪問
太多了,包括從廣域網到服務器到業務層再到架構再到程序、數據庫的各種調優,如使用緩存,靜態化,靜動態server分離,在數據量達到一定程度時,使用集群技術,優先考慮利用服務器的集群,其次是硬件集群,最后才是應用本身加入集群功能
超大數據量返回結果
緩存命中率,分頁,優化SQL語句,循環處理數據時盡可能共用對象,只保留關鍵數據,及時釋放內存占用
超大文件的讀取和生成
盡可能快的讀取大文件,并進行分析。寫入大文件時,如何及時釋放內存。學會適當利用操作系統的命令行資源來更快完成任務。這方面經驗比較少,以后有空研究。
多線程的應用和管理
線程池的管理和監控,線程的啟動(包括定時啟動),結束,回收,線程資源的釋放 ,這句話太簡單了,待深入研究
用戶界面可用性設計
平衡速度和可用性,恰當的使用異步和同步技術,展現關鍵數據為重點
分布式的數據交流和集成
選擇恰當的數據交互方式,從最泛濫低效的Web Service到最實用的文件共享
群集系統的管理
如何確保緩存的同步?如何確保對象唯一性?如何保證各臺機器的同步?
是否采用EJB?如何利用J2EE的特性(例如JNDI)
復雜的業務規則
規則引擎和工作流引擎場景和應用
其實,作為一個真正的系統架構師,不應該局限于企業應用的系統,這種系統往往有數據庫的局限性,有時候,應該考慮是否可以橫向跨越,直接對其它系統做一些架構考慮,在沒有豐富的實戰經驗的前提下,而只是看了其它人的系統和代碼,就能夠給出有效的設計指導。
例如對于一個下載軟件,可以有如下考慮:
1. 未明和非法url的檢驗,已經下載失敗的容許,信息記錄
2. 多線程下載一個文件,文件的切分和拼合,部分切片丟失的拼合可能性
3. 下載線程管理
4. 服務器或者P2P的機器之間的通訊協議
5. 速度監控和限制
6. 下載進度的監控和顯示
作為一個在線播放軟件,可以做如下考慮
1. 播放速度的保證
機器的問題基本不存在了,關鍵是網絡問題。如何在檢測網絡速度,根據影片的質量,并緩沖足夠多的內容,保證播放一直盡可能順利的完成。
2. 播放質量的保證
如何利用DirectX等技術,最快的進行渲染,是自己寫底層,還是利用已有的API
由于沒做過類似的項目,可以寫的東西還是少很多了。
系統架構師應該有的素質:
1、 實際的編程經驗
最少2年吧,多了就不說了,其實從大學就開始鉆研的話,
2、 書面表達能力和口頭交流能力
綜合利用架構圖,UML圖,文字和代碼片斷,表達自己設計思想,至于是Word還是ppt,應該通吃
在開發人員中發現架構師的最有價值標準是有效的溝通。您需要技術嫻熟、經驗豐富的開發人員,這樣的人員需要有就項目中的業務相關問題進行溝通的經歷。架構師經常必須對理解方面的差距進行預計,然后才能有所貢獻。他們必須愿意克服困難來確保技術和業務觀點的融合。他們并不必對意見交換工作進行計劃和協調;這仍然主要是項目經理的工作。他們的任務是確定表述系統設計時的最佳工具和構件,以促進有效的意見交換。他們必須能夠判斷當前方法顯得不足而需要采用新方法的情況。寫作技能也非常重要,還需要具有制作草圖的技能或使用制圖軟件的能力。
3、 自覺主動;積極解決設計問題
架構師的日常工作目標經常并不明確。很多開發人員直接參考功能規范來列出任務清單。架構師通常則是向這些開發人員提供所需結構的人員,以便盡可能提高工作效率。好的候選者不僅進行溝通方面的工作,而且也會預計各種設計問題并加以解決——通常在沒有任何具體指示的情況下自覺進行。無論所分配的職責如何,積極參與項目的開發人員都有機會從一起工作的人員中脫穎而出。
4、 抽象思維能力和總結能力
架構師,顧名思義,在系統未搭建好之前,就要能夠有一個草圖在心。而如果是對現有系統的改造,那么能在看過系統的文檔(如果有的話)和代碼后,就能總結出系統的架構特點。
架構師必須能夠理解表述模糊的概念并將其變成相關各方能夠理解的項目構件。他們必須能夠理解抽象概念,并以具體的語言對其進行溝通。開發人員中好的候選者經常要求或自己主動解釋開發生命周期中容易混淆的問題。他們能迅速評估各種想法并將其納入后續工作的操作建議中。
開發人員經常具有很強的數學能力,而好的架構師則傾向于表現出更強的口頭表達能力。管理人員經常說開發人員具有“工程意識”,而這是一個用于評估架構師的非常有意義的方面。架構師應該具有很強的解決技術問題的能力,但還必須能夠準確獲知更為全面的人員如何與技術交互的信息。這要求具有某種形式的抽象思維(而不再是代碼的細節),這種思維能力可能較難形成。
5、 全面的技術資訊吸收能力和選擇鑒別能力
作為開發人員出身,對于某一個具體問題的研究能力(雖然很多人總結為google能力),已經相當具備了。但是對技術資訊的全面接受和選擇性深入了解能力,并且做出正確的判斷,那些技術無非是廠家的噱頭,而那些技術是真正可以用到項目,提高項目質量的好技術,這種能力確實至關重要的。