一,JAVA性能優化之設計優化
設計優化處於性能優化手段的上層,它每每須要在軟件開發以前進行,在軟件開發以前,系統架構師應該就評估系統可能存在的各類潛在問題和技術難點,並給出合理的設計方案,因爲軟件設計和系統架構對軟件總體設計質量有決定性的影響,因此,設計調優對系統的性能影響也是最大的,若是說,代碼優化,JVM優化都是對系統微觀層次的「量」的優化,那設計優化就是對系統」質」的優化.
設計優化的一大顯著特徵是:它能夠規避某一個組件的性能問題,而是改良組件的實現;好比:組件A經過循環監控不斷的檢測時間E是否發生,其檢測行爲必然會佔用部分系統資源,所以,開發人員必須檢測頻率和資源消耗上取得平衡,若是檢測頻率過低,雖然減小了資源消耗,可是系統實時反應性就會下降,若是進行代碼層的調優,就須要優化檢測方法的實現及要求得一個最爲恰當的檢測頻率.對於這個問題咱們就能夠用設計模式中的觀察者模式 ,當事件E發生的時刻,由事件E通知組件A,從而觸發組件A的行爲.這種設計從根本上解決了存在性能隱患的循環監控,從根本上解決了這一問題.
進行設計優化時,設計人員和必須熟悉經常使用的設計方法,設計模式,以及基本的性能組件和經常使用的優化思想,並將其有機地集成在軟件系統中.
注意:一個良好的系統設計能夠規避不少潛在在的性能問題.所以,儘量多花些時間在系統設計上,是建立高性能程序的關鍵
二,JAVA性能優化之代碼優化
代碼調優是在軟件開發中,或者是軟件開發完成後,軟件維護過程當中進行的程序代碼的改進和優化.代碼優化涉及諸多編碼技巧,須要開發人員熟悉相關的語言API ,並在適合的場景中正確的使用相關API或類庫.同時,對算法,數據結構的靈活使用,也是代碼優化的一個重要內容.
雖然代碼優化時從微觀上對性能進行調整,可是一個」好」的實現和一個」壞」的實現對系統的影響也是很是大的.好比,一樣做爲List的實現,LinkedList和ArrayList在隨機訪問上的性能卻差了好幾個量級;好比一樣是文件讀寫的實現,使用Stream方式和使用JAVA NIO的方式,其系能可能又會是另外一個數量級.
所以,雖然與設計優化相比,筆者將代碼優化成爲在微觀層面上的優化,但它倒是對系統性能產生最直接影響的優化方法.
三,JVM優化
因爲JAVA軟件老是運行在JVM虛擬機之上,對JVM虛擬機進行優化也能必定程度上的提高JAVA程序的性能。JVM一般能夠在軟件開發後期進行,如在開發完成或者是軟件開發的某一里程碑階段。
做爲JAVA軟件的運行平臺,JVM的各項參數將會直接影響JAVA程序的性能。好比,JVM的堆大小,垃圾回收策略等等。
要進行JVM層面的調優,須要開發人員對JVM的運行原理和基本內存結構有必定的瞭解。如,堆內存的結構,GC的種類等。而後,依據引用程序的特色,設置合理的JVM啓動參數。
四,數據庫優化
對絕大部分應用系統而言,數據庫是必不可少的一部分。JAVA程序可使用JDBC的方式鏈接數據庫。對數據庫的調優能夠分爲三個部分:算法
- 在應用層對SQL語句進行優化;
- 對數據庫進行優化。
- 對數據庫軟件進行優化。
在應用層優化數據庫訪問,涉及大量的編程技巧。好比,當使用JDBC進行查詢的時候,對於大量擁有相同結構的SQL查詢,可使用PerparedStatement代替Statement,以提升數據庫的查詢效率;在使用Select語句中,顯示指定要查詢的列名 ,避免使用*
在對數據庫優化時,主要目的是創建一個具備良好表結構的數據庫。好比,爲了提升多表級聯查詢的效率,能夠合理地使用冗餘字段;對於大表,可使用行的水平切割或者相似Oracle分區的技術;爲了提升數據的查詢的效率,能夠創建有效水平切割或者相似Oracle分區表的技術;爲了提升數據庫查詢效率;在select語句中,顯示指定要查詢的列名,避免使用*。
在對數據庫進行優化時,主要目的是創建一個具備良好表結構的數據庫。好比,爲了提升多表級聯查詢效率,能夠合理地使用冗餘字段;對於大表,可使用行數據來水平切割,爲了提升數據庫的查詢效率,能夠創建有效且事宜的索引
五,JAVA性能優化之操做系統優化
操做系統,調優的手段和參數可能有所不一樣,好比,在主流Unix系統中,共享內存段,信號量,共享內存最大值(shmmax),共享內存最小值(shmmin)等都是能夠進行優化的系統資源.此外,如最大文件句柄數,虛擬內存大小,磁盤的塊大小等參數均可能對軟件的性能產生影響.配置虛擬內存界面數據庫