709
汽車大全
資源獲取模式
任何應用都需要與資源打交道,這個資源可能是文件、內存、網絡、數據庫、web服務等。特別是係統的可伸縮性和性能上,一個係統的可伸縮性很大程度上取決於該係統資源管理的可伸縮性。資源的獲取是資源生命周期的起點,因此在此階段的優化和配置對係統性能、可用性、穩定性、可伸縮性的影響是至關重要的。資源的獲取要解決 這麼兩個問題:怎麼找到資源,何時獲取資源。
資源的超找可以通過lookup模式,所謂lookup模式就是引入一個查找服務作為中介,讓資源使用者可以 找到並使用資源提供者提供的資源。這方麵一個顯然的例子就是JNDI,我們通過JNDI查找EJB、數據庫連接池等,另一個例子就是RMI,客戶端通過命名服務查找到遠程對象。查找服務提供查詢語言,也提供接口讓服務注冊到它的容器內。
何時獲取資源?根據時機的不同可以分為預先獲取模式和延遲獲取模式。如果對係統的可用性和運行時性能要求比較高,那麼可能你會預先加載或者分配所要用到的資源,通過一個資源提供者的代理對象攔截對資源的請求,返回預先加載或者分配的資源,從而提高係統性能。這方麵的例子就是 memcached,memcached啟動時預先分配內存來提高性能(相應的帶來的是內存的不能有效利用)。線程池、數據庫連接池也是預先獲取模式的例子,通過預先創建的線程或者數據庫連接,來提高係統的整體性能。反之,延遲獲取模式就是盡可能到使用資源的最後一刻才去獲取資源,一開始返回的隻是一個資源的代理對象,真正使用到資源的時候由這個代理對象去加載實際的資源。延遲獲取模式的例子也很多,例如 Hibernate的延遲加載,延遲加載的對象其實是一個代理類(通過java動態代理或者cglib增強),隻有真正用到的時候才去數據庫獲取實際的數 據。函數式編程中的延時求值也是延遲獲取模式的例子,沒有求值前隻是個promise,求值到的時候才force執行。Singleton模式下的單例也常常做延遲初始化,這是延遲獲取模式的特化。
如果資源的大小很大、極大或者是未知尺寸,預先獲取會導致係統速度的緩慢甚至耗盡係統資源,延遲獲取在獲取的時候也可能時間過長難以忍受或者耗盡係統資源,兩者都不適合,解決辦法就是分步獲取,這就是所謂部分獲取模式。將資源的獲取分為兩步或者多步,每一步獲取一定數目的資源,每一步獲取資源也可以采用預先或者延遲的策略。這樣的例子如socket讀數據到緩衝區,一次可能隻讀一部分數據到緩衝區,分步才讀完。再比如web頁麵一棵樹的展 現,一開始可能隻是顯示部分節點,在需要查看一些節點的時候才會通過ajax加載和展開它們的子結點乃至深層子結點。
參考:POSA3 第二章
文章轉自莊周夢蝶 ,原文發布時間 2008-09-07
最後更新:2017-05-17 18:31:45