1、Apache + Tomcat 結合起來用Apache負責靜態頁面,Tomcat負責動態頁面,同時減少connectionTimeout的時間,以應對並發量大線程回收來不及的情況。
2、壓力過大的問題,可以做負載均衡,一個TOMCAT無論如何也不可能擔當如此多的線程負載,而且JVM過大,其內存管理成本將顯著加大。2G的內存,做3-4個TOMCAT實例(512RAM*4),更為科學合理。
3、數據庫連接池,不少人,都推薦使用C3P0,能提高訪問數據庫的並發性能好幾倍。
4、采用Tomcat集群可以最大程度的發揮服務器的性能,可以在配置較高的服務器上部署多個Tomcat,也可以在多台服務器上分別部署Tomcat,Apache和Tomcat整合的方式還是JK方式。經過驗證,系統對大用戶量使用的響應方面,Apache+3Tomccat集群> Apache+2Tomcat集群 > Apache集成Tomcat > 單個Tomcat。並且采用Apache+多Tomcat集群的部署方式時,如果一個Tomcat出現宕機,系統可以繼續使用,所以在硬件系統性能足夠優越的情況下,需要盡量發揮軟件的性能,可以采用增加Tomcat集群的方式。
5、1. 設置MPM(Multi Processing Modules多道處理模塊)。ThreadPerChild,這個參數用於設置每個進程的線程數,在Windows環境下默認值是64,最大值是1920,建議設置為100-500之間,服務器性能高的話值大一些,反之小一些。MaxRequestPerChild表示每個子進程能夠處理的最大請求數。這個參數的值更大程度上取決於服務器的內存,如果內存比較大的話可以設置為很大的參數,否則設置一個較小的值,建議值是3000.
2. 關閉DNS和名字解析 HostnameLookups off
3. 打開UseCanonicalName模塊 UseCanonicalName on
4. 關閉多余模塊 一般來說,不需要加載的模塊有,mod_include.so、mod_autoindex.so、mod_access.so、mod_auth.so.
5. 打開KeepAlive支持
KeepAlive on, KeepAliveTimeout 15 MaxKeepAliveRequests 1000
根據實際經驗,通過Apache和Tomcat集群的方式提高系統性能的效果十分明顯,這種方式可以最大化的利用硬件資源,通過多個Tomcat的處理來分擔單Tomcat時的壓力。
web server允許的最大連接數還受制於操作系統的內核參數設置,通常Windows是2000個左右,Linux是1000個左右。