當前位置:才華齋>職業>系統架構師>

系統架構師概述

系統架構師 閲讀(6.41K)

架構師的主要責任是提供開發人員和項目經理之間的共用溝通媒體。他們負責讓業務規則及需求與工程實踐及限制相適應,以確保成功。下面yjbys小編為大家準備了關於系統架構師的文章,歡迎閲讀。

系統架構師概述

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

Thinking in Java

Effective Java

UML基礎、案例與應用

UML入門提高

軟件工匠

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

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

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

企業應用架構模式

Expert One-on-One J2EE Development without EJB

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

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

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

  企業應用的系統架構師應該關注的幾個方面

數據持久層的設計

在Spring和Hibernate,ibatis出來以前,幾乎每家公司都有自己的一套方法和架構,而架構師的50%的精力也會集中到這上面,EJB只是增加架構師的負擔。在Spring出來以後,基本上,大多數的架構師都從重複設計這個輪子的無用功中解脱出來了。Rod的輪子太好用了,基本上,大家只要套上去就行了,或者,剩下最重要的事情,是選擇一個合適的數據庫連接池的開源項目吧

MVC架構的具體設計

MVC只是個概要的概念,具體如何實現的具體技術很多,根據項目設計最恰當的架構

大併發性訪問

使用緩存,在數據量達到一定程度時,使用集羣技術,優先考慮利用服務器的集羣,其次是硬件集羣,最後才是應用本身加入集羣功能

超大數據量返回結果

儘量使用分頁,優化SQL語句,循環處理數據時儘可能共用對象,只保留關鍵數據,及時釋放內存佔用

超大文件的讀取和生成

儘可能快的讀取大文件,並進行分析。寫入大文件時,如何及時釋放內存。學會適當利用操作系統的命令行資源來更快完成任務。

多線程的應用和管理

線程池的管理和監控,線程的啟動(包括定時啟動),結束,回收,線程資源的釋放

用户界面可用性設計

平衡速度和可用性,恰當的使用異步和同步技術,展現關鍵數據為重點

分佈式的數據交流和集成

選擇恰當的數據交互方式,從最氾濫低效的Web Service到最實用的文件共享

羣集系統的.管理

如何確保緩存的同步?如何確保對象唯一性?如何保證各台機器的同步?

是否採用EJB?如何利用J2EE的特性(例如JNDI)

複雜的業務規則

規則引擎和工作流引擎場景和應用

其實,作為一個真正的系統架構師,不應該侷限於企業應用的系統,這種系統往往有數據庫的侷限性,有時候,應該考慮是否可以橫向跨越,直接對其它系統做一些架構考慮,在沒有豐富的實戰經驗的前提下,而只是看了其它人的系統和代碼,就能夠給出有效的設計指導。

例如對於一個下載軟件,可以有如下考慮:

1. 未明和非法url的檢驗,已經下載失敗的容許,信息記錄

2. 多線程下載一個文件,文件的切分和拼合,部分切片丟失的拼合可能性

3. 下載線程管理

4. 服務器或者P2P的機器之間的通訊協議

5. 速度監控和限制

6. 下載進度的監控和顯示

作為一個在線播放軟件,可以做如下考慮

1. 播放速度的保證

機器的問題基本不存在了,關鍵是網絡問題。如何在檢測網絡速度,根據影片的質量,並緩衝足夠多的內容,保證播放一直儘可能順利的完成。

2. 播放質量的保證

如何利用DirectX等技術,最快的進行渲染,是自己寫底層,還是利用已有的API

由於沒做過類似的項目,可以寫的東西還是少很多了。