欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

12個最重要的J2EE最佳實踐(2)-創(chuàng)新互聯(lián)

創(chuàng)新互聯(lián)-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設、高性價比賀蘭網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式賀蘭網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設找我們,業(yè)務覆蓋賀蘭地區(qū)。費用合理售后完善,十年實體公司更值得信賴。

12個最重要的J2EE最佳實踐(2)

7. 使用無狀態(tài)會話 bean,而不是有狀態(tài)會話 bean
這樣做可以使您的系統(tǒng)經(jīng)得起錯誤的終止。使用 HttpSession 存儲和用戶相關的狀態(tài)。
以我們的觀點看來,有狀態(tài)會話 bean 的概念已經(jīng)過時了。如果您仔細對其考慮一下,一個有狀態(tài)會話 bean 實際上與一個 CORBA 對象在體系結構上是完全相同的,無非就是一個對象實例,綁定到一個服務器,并且依賴于服務器來管理其生命周期。如果服務器關閉了,這種對象也就不存在,那么這個 bean 的客戶端的信息也就不存在。
J2EE 應用服務器為有狀態(tài)會話 bean 提供的故障轉移(failover)能夠解決一些問題,但是有狀態(tài)的解決方案沒有無狀態(tài)的解決方案易于擴展。例如,在 WebSphere Application Server 中,對無狀態(tài)會話 bean 的請求,是通過對部署無狀態(tài)會話的成員集群進行平衡加載來實現(xiàn)。相反地,J2EE 應用服務器不能對有狀態(tài) bean 的請求進行平衡加載。這意味著您的集群中的服務器的加載過程會是不均衡的。此外,使用有狀態(tài)會話 bean 將會再添加一些狀態(tài)到您的應用服務器上,這也是不好的做法。這樣就增加了系統(tǒng)的復雜性,并且在出現(xiàn)故障的情況下使問題變得復雜化。創(chuàng)建健壯的分布式系統(tǒng)的一個關鍵原則是盡量使用無狀態(tài)行為。
因此,我們建議對大多數(shù)應用程序使用無狀態(tài)會話 bean 方法。任何在處理時需要使用的與用戶相關的狀態(tài)應該以參數(shù)的形式傳送到 EJB 的方法中(并且通過使用一種機制如 HttpSession 來存儲它)或者從持久性的后端存儲(例如通過使用實體 bean)作為 EJB 事務的一部分來進行檢索。在合適的情況下,這個信息可以緩存到內(nèi)存中,但是要注意在分布式的環(huán)境中保存這種緩存所潛在的挑戰(zhàn)性。緩存非常適合于只讀數(shù)據(jù)。
總之,您要確保從一開始就要考慮到可伸展性。檢查設計中的所有設想,并且考慮到當您的應用程序要在多個服務器上運行時,是否也可以正常運行。這個規(guī)則不但適合上述情況的應用程序代碼,也適用于如 MBean 和其他管理界面的情況下。
避免使用有狀態(tài)性不只是對 IBM/WebSphere 的建議,這是一個基本的 J2EE 設計原則。
8. 使用容器管理的事務
學習一下 J2EE 中的兩階段提交事務,并且使用這種方式,而不是開放您自己的事務管理。容器在事務優(yōu)化方面幾乎總是比較好的。
使用容器管理的事務(CMT)提供了兩個關鍵的優(yōu)勢(如果沒有容器支持這幾乎是不可能的):可組合的工作單元和健壯的事務行為。
如果您的應用程序代碼顯式地使用了開始和結束事務(也許使用 javax.jts.UserTransaction 或者甚至是本地資源事務),而將來的要求需要組合模塊(也許會是代碼重構的一部分),這種情況下往往需要改變事務代碼。例如,如果模塊 A 開始了一個數(shù)據(jù)庫事務,更新數(shù)據(jù)庫,隨后提交事務,并且有模塊 B 做出同樣的處理,請考慮一下當您在模塊 C 中嘗試使用上述兩個模塊,會出現(xiàn)什么情況呢?現(xiàn)在,模塊 C 正在執(zhí)行一個邏輯動作,而這個動作實際上將調(diào)用兩個獨立的事務。如果模塊 B 在執(zhí)行中失敗了,而模塊 A 的事務仍然能被提交。這是我們所不希望出現(xiàn)的行為。如果,相反地,模塊 A 和模塊 B 都使用 CMT 的話,模塊 C 也可以開始一個 CMT(通常通過配置描述符),并且在模塊 A 和模塊 B 中的事務將是同一個事務的隱含部分,這樣就不再需要復雜的重寫代碼的工作了。
如果您的應用程序在同一個操作中需要訪問多種資源,您就要使用兩階段提交事務。例如,如果從 JMS 隊列中刪除一個消息,并且隨后更新基于這條消息的紀錄,這時,要保證這兩個操作都會執(zhí)行或都不會執(zhí)行就變得尤為重要。如果一條消息已經(jīng)從隊列中被刪除,而系統(tǒng)沒有更新與此消息相關的數(shù)據(jù)庫中的紀錄,那么這種系統(tǒng)是不穩(wěn)定的。一些嚴重的客戶及商業(yè)糾紛源自不一致的狀態(tài)。
我們時??吹揭恍┛蛻魬贸绦蛟噲D實現(xiàn)他們自己的解決方案。也許會通過應用程序的代碼在數(shù)據(jù)庫更新失敗的時候 "撤銷"對隊列的操作。我們不提倡這樣做。這種實現(xiàn)要比您最初的想象要復雜得多,并且還有許多其他的情況(想象一下如果應用程序在執(zhí)行此操作的過程中突然崩潰的情況)。作為替代的方式,應該使用兩階段提交事務。如果您使用 CMT,并且在一個單一的 CMT 中訪問兩階段提交的資源(例如 JMS 和大多數(shù)數(shù)據(jù)庫),WebSphere 將會處理所有的復雜工作。它將確保整個事務被執(zhí)行或者都不被執(zhí)行,包括系統(tǒng)崩潰、數(shù)據(jù)庫崩潰或其他的情況。其實現(xiàn)在事務日志中保存著事務狀態(tài)。當應用程序訪問多種資源的時候,我們怎么強調(diào)使用 CMT 事務的必要性都不為過。
9. 將 JSP 作為表示層的選
只有在需要多種表示輸出類型,并且輸出類型被一個單一的控制器及后端支持時才使用 XML/XSLT。
我們常聽到一些爭論說,為什么您選擇 XML/XSLT 而不是 JSP 作為表示層技術。選擇 XML/XSLT 的人的觀點是,JSP" 允許您將模型和視圖混合在一起",而 XML/XSLT 不會有這種問題。遺憾的是,這種觀點并不完全正確,或者至少不像白與黑那樣分的清楚。實際上,XSL 和 XPath 是編程語言。XSL 是圖靈完成的(Turing-complete),盡管它不符合大多數(shù)人定義的編程語言,因為它是基于規(guī)則的,并且不具備程序員習慣的控制工具。
現(xiàn)在的問題是既然給予了這種靈活性,開發(fā)人員就會利用這種靈活性。盡管每個人都認同 JSP 使開發(fā)人員容易在視圖中加入"類似模型"的行為,而實際上,在 XSL 中也有可能做出一些同樣的事情。盡管從 XSL 中進行訪問數(shù)據(jù)庫這樣的事情會非常困難,但是我們曾經(jīng)見到過一些異常復雜的 XSLT 樣式表執(zhí)行復雜的轉換,這實際上是模型代碼。
然而,應該選擇 JSP 作為選的表示技術的最基本的原因是,JSP 是現(xiàn)在支持最廣泛的、也是最被廣泛理解的 J2EE 視圖技術。而隨著自定義標記庫、JSTL 和 JSP2.0 的新特性的引入,創(chuàng)建 JSP 變得更加容易,并且不需要任何 Java 代碼,以及可以將模型和視圖清晰的分離開。在一些開發(fā)環(huán)境中(如 WebSphere Studio)加入了對 JSP(包括對調(diào)試的支持)的強大支持,并且許多開發(fā)人員發(fā)現(xiàn)使用 JSP 進行開發(fā)要比使用 XLS 簡單,一些支持 JSP 的圖形設計工具及其他特征(尤其在 JSF 這樣的框架下)使得開發(fā)人員可以以所見即所得的方式進行 JSP 的開發(fā),而對于 XSL 有時不容易做到。
最后一個要謹慎考慮使用 JSP 的原因是速度問題。在 IBM 所作的對比 XSL 和 JSP 相對速度的性能測試顯示:在大多數(shù)情況下,JSP 在生成同樣的 HTML 的時候,要比 XSL 快好幾倍,甚至使用編譯過的 XSL 也是如此。盡管多數(shù)情況下這不是問題,但在性能要求很高的情況下,這就會成為問題。
然而,這也不能說,您永遠也不要使用 XSL。在一些情況下,XSL 能夠表示一組固定的數(shù)據(jù),并且可以基于不同的樣式表來以不同的方式顯示這些數(shù)據(jù)的能力是顯示視圖的最佳解決方案。然而,這只是一種例外的情況,而不是通用的規(guī)則。如果您只是生成 HTML 來表達每一個頁面,那么在大多數(shù)情況下,XSL 是一種不必要的技術,并且,它給您的開發(fā)人員所帶來的問題遠比它所能解決的問題多。
10. 當使用 HttpSession 時,盡量只將當前事務所需要的狀態(tài)保存其中,其他內(nèi)容不要保存在 HttpSession 中。

啟用會話持久性。
HttpSessions 對于存儲應用程序狀態(tài)信息是非常有用的。其 API 易于使用和理解。遺憾的是,開發(fā)人員常常遺忘了 HttpSession 的目的----用來保持暫時的用戶狀態(tài)。它不是任意的數(shù)據(jù)緩存。我們已經(jīng)見到過太多的系統(tǒng)為每個用戶的會話放入了大量的數(shù)據(jù)(達到兆字節(jié))。那好了,如果同時有 1000 個登錄系統(tǒng)的用戶,每個用戶擁有 1MB 的會話數(shù)據(jù),那么就需要 1G 或者更多的內(nèi)存用于這些會話。要使這些 HTTP 會話數(shù)據(jù)較小一些,不然的話,您的應用程序的性能將會下降。一個大約比較合適的數(shù)據(jù)量應該是每個用戶的會話數(shù)據(jù)在 2K-4K 之間,這不是一個硬性的規(guī)則,8K 仍然沒有問題,但是顯然會比 2K 時的速度要慢。一定要注意,不要使 HttpSession 變成數(shù)據(jù)堆積的場所。
一個常見的問題是使用 HttpSession 緩存一些很容易再創(chuàng)建的信息,如果有必要的話。由于會話是持久性的,進行不必要的序列化以及寫入數(shù)據(jù)是一種很奢侈的決定。相反地,應該使用內(nèi)存中的哈希表來緩存數(shù)據(jù),并且在會話中保存一個對此數(shù)據(jù)進行引用的關鍵字。這樣,如果不能成功登錄到另外的應用服務器的話,就可以重新創(chuàng)建數(shù)據(jù)。
當談及會話持久性時,不要忘記要啟用這項功能。如果您沒有啟用會話持久性,或者服務器因為某種原因停止了(服務器故障或正常的維護),則所有此應用服務的當前用戶的會話將會丟失。這是件令人非常不高興的事情。用戶不得不重新登錄,并且重新做一些他們曾經(jīng)已經(jīng)做過的事情。相反地,如果啟用了會話持久性,WebSphere 會自動將用戶(以及他們的會話)移到另外一個應用服務器上去。用戶甚至不知道會有這種事情的發(fā)生。我們曾經(jīng)見到過一些產(chǎn)品系統(tǒng)因為存在于本地代碼中令人難以忍受的 bug(不是 IBM 的代碼?。┒蝗槐罎⒌那闆r,這這種情況下,上述功能仍然可以運行良好。
11. 在 WebSphere 中,使用動態(tài)緩存,并使用 WebSphere servlet 緩存機制。
通過使用這些功能,系統(tǒng)性能可以得到很大的提高,而開銷是很小的。并且不影響編程模型。
通過緩存來提高性能的好處是眾所周知的事情。遺憾的是,當前的 J2EE 規(guī)范沒有包括一種用于 servlet/JSP 緩存的機制。然而,WebSphere 提供了對頁面以及片斷緩存的支持,這種支持是通過其動態(tài)緩存功能來實現(xiàn)的,并且不需要對應用程序作出任何改變。其緩存的策略是聲明性的,而且其配置是通過 XML 配置描述符來實現(xiàn)的。因此,您的應用程序不會受到影響,并保持與 J2EE 規(guī)范的兼容性和移植性,同時還從 WebSphere 的 servlet 及 JSP 的緩存機制中得到性能的優(yōu)化。
從 servet 及 JSP 的動態(tài)緩存機制得到的性能的提高是顯而易見的,這取決于應用程序的特性。Cox 和 Martin [Cox] 指出對一個現(xiàn)有的 RDF(資源描述格式)站點摘要 (RSS)servlet,當使用動態(tài)緩存時,其性能可以提高 10%。請注意這個實驗只涉及到一個簡單的 servlet,這個性能的增長量可能并不能反映一個復雜的應用程序。
為了更多地提高性能,將 WebSphere servlet/JSP 結果緩存與 WebSphere 插件 ESI Fragment 處理器、IBM HTTP Server Fast Response Cache Accelerator (FRCA) 和 Edge Server 緩存功能集成在一起。對于繁重的基于讀取的工作負荷,通過使用這些功能可以得到許多額外的好處。
12. 為了提高程序員的工作效率,將 CMP 實體 bean 作為 O/R 映射的選解決方案.
通過 WebSphere 框架(readahead、緩存、隔離級別等)優(yōu)化性能。如果可能,有選擇的應用一些模式來達到提高性能的目的,例如 Fast-Lane 閱讀器 [Marinescu]。
對象/關系(O/R)映射是使用 Java 創(chuàng)建企業(yè)級的應用程序的基礎。幾乎每個 J2EE 應用程序都需要一些類型的 O/R 映射。J2EE 廠商提供一種 O/R 映射機制,這種機制在不同的廠商間是可移植的,高效的,并且能夠被一些標準及工具很好地支持。這就是 EJB 規(guī)范中的 CMP(容器管理的持久性)部分。
早期的 CMP 實現(xiàn)以表現(xiàn)不佳及不支持許多 SQL 結構而著稱。然而,隨著 EJB 2.0 及 2.1 規(guī)范的出現(xiàn),以及被一些廠商所采納,并且隨著像 IBM WebSphere Studio Application Developer 的出現(xiàn),這些問題已經(jīng)不再是問題了。
CMP EJB 組件現(xiàn)在已經(jīng)被廣泛地應用于許多高性能的應用程序中。WebSphere 包括一些優(yōu)化功能以提高 EJB 組件的性能,優(yōu)化功能包括:對生命周期的緩存和 read-ahead 能力。這兩者優(yōu)化功能都是配置時的選項,并且不需要對應用程序進行修改或者影響可移植性。
處于緩存狀態(tài)的生命周期緩存 CMP 狀態(tài)數(shù)據(jù)并提供基于時間的無效性。從處于緩存狀態(tài)的生命周期得到的性能提高可以達到選項 A 的緩存性能,并且仍然可以為您的應用程序提供可伸展性。Read-ahead 能力和容器管理的關系結合使用。這個特性通過在相同的查詢中隨意地檢索相關的數(shù)據(jù)作為父數(shù)據(jù)而減少與數(shù)據(jù)庫的交互。如果相關的數(shù)據(jù)要通過使用并發(fā)的查詢來訪問的話,這種方法可以得到性能的改進。[Gunther]提供了詳細的描述以及通過這些特性得到的性能提高的細節(jié)。
此外,為了完全優(yōu)化您的 EJB 組件,當指定隔離級別時要特別注意。盡可能使用最低的隔離級別,并且仍然保持您的數(shù)據(jù)的完整性。較低的隔離級別可以提供最佳的性能,并且可以降低出現(xiàn)數(shù)據(jù)庫死鎖的危險。
這是目前最有爭議的最佳實踐。已經(jīng)有大量的文章贊揚 CMP EJB,同樣的貶斥聲也不絕于耳。然而,這里最基本的問題是數(shù)據(jù)庫開發(fā)是困難的。當您開始使用任何持久性解決方案之前,您需要掌握查詢以及數(shù)據(jù)庫鎖定如何工作這些基礎知識。如果您選擇使用 CMP EJB,您要確保您已經(jīng)通過一些書籍(例如 [Brown] 和 [Barcia])知道如何使用它們。在鎖定及爭用方面有一些微妙的交互難以理解,但是,在您耗費一定的時間及努力后會將其掌握的。

名稱欄目:12個最重要的J2EE最佳實踐(2)-創(chuàng)新互聯(lián)
文章地址:http://aaarwkj.com/article20/cocejo.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供自適應網(wǎng)站定制開發(fā)、微信小程序建站公司、做網(wǎng)站、網(wǎng)站內(nèi)鏈

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站制作
97水蜜桃视频在线观看| 老司机看片午夜久久福利| 91熟女成人精品一区二区| 综合资源网日韩天天操| 玩弄丰满熟妇留守妇女| 成人黄网站色大片免费观看| 欧美日韩国产亚洲免费| av一区二区日韩精品久| 欧美性生活真实的视频| 亚洲国产成人午夜精品| 婷婷六月亚洲中文字幕| 免费观看国产性生活片| 国产一区二区黄色在线| 国产激情一区二区三区| 未满十八禁止观看免费观看| 麻豆剧传媒国产精选av| 国产高跟丝袜av专区| 午夜美女精品福利视频| 久久精品视频亚洲一级| 91久久亚洲综合精品成人| 国产精品伊人久久综合网| 亚洲国产精品一区二区电影| 在线 | 一区二区三区四区| 亚洲综合一区二区在线视频| 国产91黑丝视频在线观看 | 欧美一区二区三区亚洲| 中文字幕国产精品综合一区| 深夜视频国产在线观看| 国产又粗又长又猛又爽视频| 欧美影院波波在线影院| 蜜臀99久久精品久久久| 熟女另类视频在线观看| 在线观看男人的天堂av| 人妻少妇被猛烈进入久久精品| 在线亚洲精品一区二区| 国产激情一区二区三区不卡| 一区二区三区毛片在线看| 精品一区二区久久久久久| 91精品超碰人人在线公开| 综合久久久精品国产亚洲av| 精品人妻va人妻中文字幕麻豆|