Sky's blog

          我和我追逐的夢

          常用鏈接

          統計

          其他鏈接

          友情鏈接

          最新評論

          07 2008 檔案

          ejb與java序列化(3)--開啟enable-call-by-reference
               摘要: 問題終于找到,簡單的說是因為java 系列化的效率低下,而ejb調用之間又大量使用系列化,因此造成極大的性能消耗,而且也影響到響應時間。仔細分析了一下項目情況,呵呵,情況非常嚴重,系統架構是按照三層來設計的,每個層都是ejb,調下一層都是通過遠程接口,而且層之間可能還多個ejb的調用。
          總結一下:
          1. java serialize 非常慢
          2. enable-call-by-reference可以有效避免這個開銷
          因此,能enable-call-by-reference就盡量enable-call-by-reference。  閱讀全文

          posted @ 2008-07-29 12:03 sky ao 閱讀(1771) | 評論 (5)  編輯

          ejb與java序列化(2)--測試代碼
               摘要: 接上篇,有興趣的朋友可以直接拿我的測試代碼自行測試,請自行修改諸如線程數,執行時間,系列化的數據量大小等參數。如果想嘗試做thread dump,可以打開相關的兩個注釋,會更方便一些,代碼中都有相應的注釋可供參考。  閱讀全文

          posted @ 2008-07-29 10:36 sky ao 閱讀(1168) | 評論 (0)  編輯

          ejb與java序列化(1)--發現并分析問題
               摘要: 這是加入新公司后接手的第一個項目,使用weblogic9.2 + ejb2.0,壓力測試時發現速度非常慢,響應時間很不理想,檢查日志發現,某些ejb相互調用時方法調用的時間非常長,高達300-500毫秒。非常夸張,因為兩個日志之間只是間隔了一個ejb調用。通過thread dump分析后發現有相當多的線程在wait,檢查線程調用綻發現是在將參數進行序列化時,線程試圖加鎖但是鎖被占用,因此處于等待狀態。考慮到 thread dump的這一瞬間,有多達30-50個線程都在同時試圖在同一個鎖上加鎖,很明顯這里的鎖競爭非常嚴重。

          因此強烈懷疑是java的序列化機制導致的問題。  閱讀全文

          posted @ 2008-07-29 10:21 sky ao 閱讀(1431) | 評論 (0)  編輯

          主站蜘蛛池模板: 温州市| 民权县| 海安县| 青龙| 自贡市| 唐海县| 重庆市| 繁峙县| 天全县| 苗栗市| 扬州市| 云梦县| 监利县| 万盛区| 平顶山市| 甘德县| 乡城县| 信阳市| 秦皇岛市| 盘锦市| 武安市| 米林县| 三明市| 高尔夫| 河源市| 郴州市| 嘉定区| 邯郸市| 郓城县| 宣武区| 汉川市| 龙门县| 兴隆县| 沭阳县| 岑溪市| 澄城县| 舟曲县| 绩溪县| 怀远县| 宝应县| 巴彦县|