Atitit.軟體架構高擴展性and相容性原理與概論實踐attilax總結 1. 什麼是可擴展的應用程式?1 2. 松耦合(ioc)2 3. 介面的思考 2 4. 單一用途&模塊化,小粒度化2 5. 組合(Composition),而不是繼承(inheritance) 2 6. Ocp原則開閉原則2 ...
Atitit.軟體架構高擴展性and相容性原理與概論實踐attilax總結
5. 組合(Composition),而不是繼承(inheritance) 2
12. 表處理擴展if else (數據與數據處理相互分離)3
15.5. 不同項目的同一功能就實現可以放在同一上級模塊package下5
16. 架構即未來:現代企業可擴展的Web架構、流程和組織(原書第2版)5
17. 高擴展性網站的50條原則(網站運營必備寶典)作者:[美]Martin L. AbbottMichael T. Fisher 著6
1. 什麼是可擴展的應用程式?
一個可擴展的應用程式應該能夠以某種方式實現增長,並且添加、刪除、增強、重構某些組件,對於其他組件的影響微乎其微
當出現下麵的這些情況時,說明元素已經具有可擴展性了:
· 該元素可以很容易地與其他元素進行互換,而不會破壞應用程式
· 該元素可以輕鬆重用於項目外部
· 該元素可以成功地進行單元測試
2. 松耦合(ioc)
soma.js中提供了一系列用於架構解耦和測試的工具,以及各種設計模式解決方案,比如依賴註入(dependency injection)、觀察者模式(observer pattern)、中介者模式(mediator pattern)、外觀模式(facade pattern)、命令模式(command pattern),面向對象(OOP)工具集,並提供了一個DOM操作模板引擎作為可選插件。
作者:: 綽號:老哇的爪子 ( 全名::Attilax Akbar Al Rapanui 阿提拉克斯 阿克巴 阿爾 拉帕努伊 )
漢字名:艾提拉(艾龍), EMAIL:[email protected]
轉載請註明來源: http://www.cnblogs.com/attilax/
3. 介面的思考
4. 單一用途&模塊化,小粒度化
粒度更小,更容易擴展
5. 組合(Composition),而不是繼承(inheritance)
6. Ocp原則開閉原則
7. Plugin系統
8. 流程擴展工作流系統,流程自定義
9. Ui擴展 html5
10. 數據獨立性
每個功能使用不同的獨立數據,這樣可以提升擴展性。。比如訂單處理。。接受訂單,處理訂單*update ,使用不同的表 ,就可以互相不影響的功能修改以及表結構修改。。
11. 腳本與hotdeploy
12. 表處理擴展if else (數據與數據處理相互分離)
13. 系統被擴展的幾種形式(方法級別,模塊級別)
4)運行時對象裝配。
5)5)基於模塊的運行時動態擴展。 到現在為止,我們討論的都是比較細粒度的在技術上的擴展。想象一下,如果增加一些功能,就去繼承各種各樣的類,然後經過複雜的裝配過程,才能完成一個功能的添加和改進。即使你新增加了類,改動了Spring的配置文件,實現新的裝配,但仍然有一點,你需要編譯整個項目。也就是說,前四種都沒有達到模塊級別的擴展。
OSGi給出瞭解決方案,可以實現模塊級別的動態擴展,而且是運行時的。所謂運行時模塊的動態擴展,比如說你需要增加一些新的功能,你可以將新開發的類和文件按照Bundle進行組織,然後直接扔到運行時環境下,這些功能就可以用了。
6)6)基於中間語言。 框架通常定義了一些Hotspot(熱點),在這些點上,可以進行擴展。平臺,可擴展性是最強的,比如window 平臺,你可以開發應用程式運行在上面。windows提供了幾千個API,你可以使用他們來開發應用程式
由此推斷,從技術上來說,要獲得最大的可擴展性,就要通過一種或多種中間語言來進行擴展。比如現在流行的OpenSocial API和Facebook都是這個思路。這樣說來,DSL的出現就是順理成章的了,它是為了滿足在某個業務領域的擴展而設計的
14. 常用軟體擴展機制
14.1. Ff的擴展機制》》》》插件體系
14.2. 配置化
14.3. dsl
15. 面臨的擴展性與相容性問題
15.1. 不同的項目與不同的實例啟動
通過不同的bat啟動文件來實現。。
可以通過啟動腳本來設置不同的實例
15.2. 不同的項目與實例配置文件
參照mysql,通過制定配置文件來實現
15.3. Web.xml怎麼辦??
暫時沒辦法,可以通過jetty等可編程中間件來實現。。
15.4. 跳轉到同一功能spec的不同實現
比如游戲和點播系統的用戶中心,ui界面就不同。。
可以使用查表法。。使用js,根據項目的id來跳轉不同的功能ui載入,項目id在啟動腳本裡面傳入。。 同一項目的不同實例只能跳轉到相同功能,如果需要不同,在加個實例id判斷吧。。
Prjid,instan_id,fun_implet
15.5. 不同項目的同一功能就實現可以放在同一上級模塊package下
重名問題,通過添加尾碼_prj 來解決。。
如果項目很多,應該通過首碼來解決,這樣好找。。
16. 架構即未來:現代企業可擴展的Web架構、流程和組織(原書第2版)
第一部分 可擴展性組織的人員配置
第1章 人員和領導力對擴展性的影響 …… 2
第2章 可擴展性技術組織的角色 …… 17
第3章 組織的設置 …… 41
第4章 領導力秘籍 …… 80
第5章 管理秘籍 …… 116
第6章 關係、思維和商業案例 …… 141
第二部分 構建可擴展的過程
第7章 過程是可擴展的關鍵 …… 154
第8章 管理故障和問題 …… 169
第9章 危機管理和升級 …… 189
第10章 生產環境的變更管理 …… 210
第11章 確定應用發展的預留空間 …… 233
第12章 確立架構原則 …… 248
第13章 聯合架構設計和架構審查委員會 …… 267
第14章 敏捷架構設計 …… 284
第15章 聚焦核心競爭力:自建與外購 …… 296
第16章 確定風險 …… 310
第17章 性能與壓力測試 …… 328
第18章 障礙條件與回滾 …… 351
第三部分 可擴展的架構方案
第19章 構建故障隔離的架構 …… 368
第20章 AKF擴展立方體介紹 …… 389
第21章 為擴展分割應用 …… 404
第22章 為擴展分割資料庫 …… 426
第23章 為擴展而緩存 …… 452
第24章 為擴展而非同步 …… 472
第四部分 其他的問題和挑戰
第25章 海量數據 …… 492
第26章 雲計算的突飛猛進 …… 517
第27章 雲計算準備就緒 …… 550
第28章 應用監控 …… 564
第29章 規劃數據中心 …… 581
第30章 縱觀全局 …… 608
17. 高擴展性網站的50條原則(網站運營必備寶典)作者:[美]Martin L. AbbottMichael T. Fisher 著
第1章 化簡方程 1
第2章 分佈工作 23
第3章 橫向擴展設計 35
第4章 使用正確的工具 51
第5章 不要重覆工作 67
第6章 積極利用緩存 81
第7章 從錯誤中吸取教訓 109
第8章 資料庫原則 125
第9章 容錯設計與故障控制 141
第10章 避免或分髮狀態 159
第11章 非同步通信和消息匯流排 171
第12章 其他原則 183
第13章 原則回顧和優先順序劃分 203
參考資料
如何一步一步打造高可擴展性的應用程式?-CSDN.NET.html
軟體可擴展性:來自星巴克的經驗 - Java,java框架 - language - ITeye論壇.html
可擴展性(Extensibility)——構建靈活系統的思考 - me.think(everything.about(_software_)).serialize(this);__古路刀客 - ITeye技術網站.html
架構師不可不知的十大可擴展架構 - 51CTO.COM.html( imp ,還沒看完)
atiend