from IBM
創(chuàng)新互聯(lián)公司擁有10年成都網(wǎng)站建設(shè)工作經(jīng)驗,為各大企業(yè)提供成都做網(wǎng)站、網(wǎng)站制作、成都外貿(mào)網(wǎng)站建設(shè)服務(wù),對于網(wǎng)頁設(shè)計、PC網(wǎng)站建設(shè)(電腦版網(wǎng)站建設(shè))、成都App制作、wap網(wǎng)站建設(shè)(手機版網(wǎng)站建設(shè))、程序開發(fā)、網(wǎng)站優(yōu)化(SEO優(yōu)化)、微網(wǎng)站、空間域名等,憑借多年來在互聯(lián)網(wǎng)的打拼,我們在互聯(lián)網(wǎng)網(wǎng)站建設(shè)行業(yè)積累了很多網(wǎng)站制作、網(wǎng)站設(shè)計、網(wǎng)絡(luò)營銷經(jīng)驗,集策劃、開發(fā)、設(shè)計、營銷、管理等網(wǎng)站化運作于一體,具備承接各種規(guī)模類型的網(wǎng)站建設(shè)項目的能力。
Java 性能準則
在編寫Java應(yīng)用程序時,以下是基本的準則:
監(jiān)視 Java
在AIX 操作系統(tǒng)中有許多工具可以用來監(jiān)視Java應(yīng)用程序的性能,以下是簡單的概述。
vmstat
這條命令提供了各種系統(tǒng)資源的信息。它報告了運行隊列以及等待隊列中內(nèi)核線程的統(tǒng)計信息、內(nèi)存使用、頁面調(diào)度空間、磁盤 I/O、中斷、系統(tǒng)調(diào)用、上下文切換以及 CPU 活動。
iostat
這條命令報告了詳細的磁盤 I/O 信息。
topas
這條命令報告了 CPU、網(wǎng)絡(luò)、磁盤 I/O、工作負載管理器和進程活動。
tprof -k -s -e -x "sleep 10"
這條命令可被用來剖析應(yīng)用程序以查明任何可能影響性能的活動程序/方法。
ps -mo 線程
這條命令顯示了一個進程或線程綁定于哪一個 CPU。
java -verbose:gc
這個選項可被用來檢查垃圾回收對您的應(yīng)用程序的沖擊。它報告了垃圾回收所花的總共時間,平均每一次垃圾回收花費時間,平均每一次垃圾回收收集的內(nèi)存以及平均每一次垃圾回收中的對象數(shù)。
Java應(yīng)用程序性能調(diào)優(yōu)
建議在運行Java應(yīng)用的AIX用戶環(huán)境下,設(shè)置以下環(huán)境變量。
AIXTHREAD_SCOPE=S
用 AIX 4.3.1 啟動,此變量缺省值為 P。這表示進程寬度爭用作用域(M:N)。對于 Java 應(yīng)用程序,您應(yīng)該設(shè)置這個值為 S,它表示系統(tǒng)寬度爭用作用域(1:1)。
AIXTHREAD_MUTEX_DEBUG=OFF
用調(diào)試器為使用目的維持一個活動人工干預(yù)列表。
AIXTHERAD_COND_DEBUG=OFF
用調(diào)試器為使用目的維持一個條件變量列表。
AIXTHREAD_RWLOCK_DEBUG=OFF
pthreads
庫用調(diào)試器為使用目的維護一個包含活動互斥鎖定、條件變量以及讀/寫鎖定的列表。當(dāng)一個鎖定初始化,如果列表中沒有這一鎖定,它被加入到列表中。此列表以
鏈表形式實現(xiàn),因此當(dāng)列表變大時通過搜索它來確定一個鎖定是否存在就包含了性能問題。問題是此列表被鎖定保護,這一鎖定在搜索操作過程中一直保持。當(dāng)搜索
進行時其它對 pthread_mutex_init() 調(diào)用的子例程必須等待。為了優(yōu)化性能,您應(yīng)當(dāng)將此線程調(diào)試選項設(shè)置為
OFF。它們的缺省值為 ON 。
SPINLOOPTIME=500
spinloop
時間是一個進程在阻塞前在一個繁忙的鎖定上可以循環(huán)的次數(shù)。這個值缺省設(shè)置為 40。如果 tprof 輸出表明 check_lock 例程具有高的
CPU 使用率,并且如果通常鎖定在短時間內(nèi)可用,您應(yīng)當(dāng)通過將值設(shè)置為 500 或更高來提高循環(huán)時間。
同樣,運行Java應(yīng)用的AIX用戶環(huán)境下,推薦以下設(shè)置:
l ulimit -d 不限制
l ulimit -m 不限制
l ulimit -n 不限制
l ulimit -s 不限制
操作系統(tǒng)內(nèi)一定的環(huán)境參數(shù)和設(shè)置可以用來調(diào)優(yōu) Java 性能。同樣,許多調(diào)優(yōu)系統(tǒng)部件如 CPU、內(nèi)存、網(wǎng)絡(luò)、I/O 等等的技術(shù),可以提高 Java 性能。
為了使得 Java 的性能和可伸縮性盡可能的好,您應(yīng)當(dāng)使用最新可用版本的操作系統(tǒng)和 Java,以及Just-In-Time(JIT)編譯器。
與 Java 相關(guān)的最普通的性能問題與垃圾回收機制有關(guān)。如果 Java 堆太大,則堆將必須駐留在主內(nèi)存外。這將導(dǎo)致頁面調(diào)度活動增加,它將影響 Java 性能。同樣,一個大的堆可能花很多秒去填充。這意味著,盡管垃圾回收活動不頻繁,但與垃圾回收相聯(lián)系的暫停次數(shù)將增加。為了調(diào)優(yōu) Java 虛擬機(JVM)的堆,使用 java 命令加選項 -ms 或 -mx。使用垃圾回收統(tǒng)計信息來幫助決定最佳設(shè)置。[@more@]