本文目錄一覽:
高並發原理 用java怎麼優化
面對高並發高請求的大型JAVA應用場景,需要考慮到以下幾個方面並並進行優化:
1、代碼方面
從最基礎的做起,優化所寫代碼,減少不必要的資源浪費,比如:避免頻繁的new對象,優先考慮使用單例模式、減繁去重,重用代碼要歸納成公用方法,相關工具類使用靜態方法訪問、使用java中效率高的類等等;
2、資料庫方面
當面對複雜的應用,用戶大量訪問的時候,一台數據很快無法滿足需求,這時就需要使用資料庫集群或者庫表散列。
常用的優化措施是M-S(主-從)方式進行同步複製,將查詢和操作和分別在不同的伺服器上進行操作,這樣會大大減少資料庫操作耗時;
3、靜態資源方面
我們可以把一些訪問頻次高但是變更不大的動態請求提前渲染生成html靜態頁面,然後每次用戶再訪問該請求時,就不要再調用伺服器請求了,這樣會大大減少高峰期時伺服器的壓力;
在靜態資源例如圖片、js、css等方面,我們可以將這些資源與核心應用和html資源分離開,建立合適的靜態文件伺服器,針對不同類型的靜態資源對伺服器進行優化配置,這樣就不會再高並發時因為這些靜態資源的問題而使整個頁面崩潰了;
4、其他方面
緩存:盡量使用緩存,包括用戶緩存,信息緩存等,多花點內存來做緩存,可以大量減少與資料庫的交互,提高性能。
可以考慮memcached緩存集群和靜態HTML、Redis緩存
負載均衡:nginx(非同步)、squid(同步)、lighttpd(非同步)
存儲:分散式的,如hadop等
Java多線程MasterWorker模式如何在高並發情況下優化
你說的Master指的是java的線程池吧,我之前做過一個項目,因為項目在內網拿不出來,我給你說一下我那次的經驗。
幾個關鍵點:
1、java線程池:使用java提供的ThreadPoolExecutor類構造主池,再構造一個輔池(輔池的作用在於當主池進入拒絕策略的時候,可以啟動輔池,幫助主池分擔一部分線程,或者在主池shutdown的瞬間又有任務進來,也會走到拒絕策略,此時可以啟動輔池處理這些線程,一般情況下輔池不會啟動),排隊策略使用LinkedBlockingQueue隊列。
2、單例模式:利用spring的IOC容器的單例性,每次取線程池時,從IOC容器中注入。創建一個組件類BatPool(spring組件默認為單例),裡面再使用單例模式創建線程池,單例中的單例,保證單例性:
@Component
class BatPool{
private ThreadPoolExecutor mainPool;
ThreadPoolExecutor create(){
if(mainPool== null){
retrun new ThreadPoolExecutor();
}else{
retrun mainPool;
}
…
}
業務中:
@Autowired
BatPool batPool;
ThreadPoolExecutor pool = batPool.create();
…
線程池的配置你自己參考網上吧
這樣在業務中,每次取到的池都是同一個池,不會多次創建。
如果你沒有使用spring的話,我再想想辦法怎麼實現全局的單例模式
java高並發是什麼意思,高並發的解釋
1、在java中,高並發屬於一種編程術語,意思就是有很多用戶在訪問,導致系統數據不正確、糗事數據的現象。並發就是可以使用多個線程或進程,同時處理不同的操作。
2、處理高並發的方法
對於一些大型網站,比如門戶網站,在面對大量用戶訪問、高並發請求方面,基本的解決方案集中在這樣幾個環節:使用高性能的伺服器、高性能的資料庫、高效率的編程語言、還有高性能的Web容器。
(1)動靜分離。靜態資源請求與動態請求分離,項目中需要訪問的圖片、聲音、js/css等靜態資源需要有獨立的存放位置,便於將來實現靜態請求分離時直接剝離出來,比如nginx可以直接配置圖片文件直接訪問目錄,而不需要經過tomcat。這樣tomcat就可以專註處理動態請求,操作資料庫數據處理之類的。靜態請求代理伺服器性能比tomcat高很多。
(2)引入緩存。資料庫緩存、頁面緩存,這東西好用不複雜,搞明白什麼地方適用最重要。簡單的例子是頻繁讀取,不修改的地方最適用。也是後續集群做數據共享的一個方式之一,集群環境下,經常會碰到數據共享問題。
(3)如果將來數據量大,單一資料庫成為瓶頸時,資料庫的讀寫分離來了。資料庫集群,讀寫分離,分表分區。
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/231443.html