首頁 >Java >java教程 >java怎麼處理高並發?

java怎麼處理高並發?

青灯夜游
青灯夜游原創
2019-05-22 16:39:1629808瀏覽

java處理高並發的方法:1、優化程式碼,減少不必要的資源浪費;2、把圖片與頁面進行分離,將圖片放到獨立的圖片服器;3、使用緩存,可以大量減少與資料庫的交互,提高效能;4、使用資料庫叢集;5、進行DB最佳化;6、硬體上做到負載平衡等等。

java怎麼處理高並發?

java處理高並發的方法:

1、從最基礎的地方做起,優化我們寫的程式碼,減少不必要的資源浪費。

  a、避免頻繁的使用new對象,對於整個應用只需要存在一個實例的類,我們可以使用單例模式。對於String連線操作,使用StringBuffer或StringBuilder,對於工具類別可以透過靜態方法來存取。

  b、避免使用錯誤的方式,盡量不用instanceof來做條件判斷。使用java中效率高的類,例如ArrayList比Vector效能好。

影片課程推薦→:《千萬資料並發解決方案(理論實戰)》

2、 html靜態化

我們透過一個連結位址訪問,透過這個連結位址,伺服器對應的模組處理這個請求,轉到對應的jsp頁面,最後產生我們要的資料。但是,如果上千萬個請求的話,有太多的高並發請求,那麼就會加重伺服器的壓力,最壞的情況是把伺服器down掉。那麼該如何避免這種情況的出現呢?如果我們把最初對test.do的請求結果存成一個html文件,然後每次用戶都去訪問這個html文件,這樣就不用再去訪問伺服器了,伺服器的壓力不就減少了?

那如何自動的生成靜態頁面,當使用者去訪問,會自動的生成test.html ,然後再顯示給使用者。

3、圖片伺服器分離

對於web伺服器來說,圖片是最消耗資源的,於是我們有必要把圖片與頁面進行分離,我們把圖片放到獨立的圖片伺服器。這樣的架構可以降低提供頁面存取請求的伺服器系統壓力,並且可以確保系統不會因為圖片的問題而崩潰。在圖片伺服器上,我們可以對不同的配置進行最佳化。

4、使用緩存

盡量使用緩存,包括用戶緩存,資訊緩存等,多花點記憶體來做緩存,可以大量減少與資料庫的交互,提高效能。

5、分批傳送

在做某項目的時候,一次傳遞的參數太多,而且資料庫規定一次最多傳遞的參數最多是三萬條,當時有五萬條記錄,那怎麼傳送呢?最後是分批傳送,電梯裡一次乘不下那麼多的人,會報超重的bug,那就分批把人送上去。

還有一次在考試系統中,如果那麼多的考試人員同時提交到資料庫中,資料庫的壓力增大,有時會被down掉,當時採用的方法是使用ajax異步傳輸,沒有等待考生點擊提交按鈕的時候,就把考生的答案自動提交,這樣也避免了突然斷電考生前面做過的題出現丟失的現象。

6、資料庫叢集

當面對複雜的應用,使用者大量存取的時候,一台資料很快就無法滿足需求,於是我們需要使用資料庫叢集或庫表雜湊。

我們在應用程式中安裝業務和應用程式或功能模組將資料分離,不同的模組對應不同的資料庫或表,再按照一定的策略對某個頁面或功能進行更小的資料庫散列。

7、DB最佳化

   a、在資料庫設計的時候就要考慮到後期的維護,資料庫三範式是我們設計資料庫要求遵循的原則。

   b、索引的建立:建立索引要適當,如果一個表經常用來被查詢,對於增加和修改很少被用到,我們就可以為這個表建立索引,因為對於增加和修改和刪除操作時,我們對索引的維護要大大超過索引帶給我們的效率。

   c、表格欄位的類型選擇要適當包含欄位的長度、類型等,要依照實際儲存的資料進行選擇,長度不要過長,否則會影響效率。

   d、外鍵要慎用,因為主鍵代表這張表,而外鍵代表一群表,對錶之間進行了關聯,在刪除修改等需要我們關聯。

   e、在資料庫作業上

     盡量使用prepareStatement,少用Statement,因為PrepareStatement是預先編譯的。

     connection設定為readOnly,Connection是對書庫連接,屬於重量級,我們使用即可。

     連接池的使用,我們可以修改資料庫預設的連線數。

8、硬體上做到負載平衡

#

以上是java怎麼處理高並發?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn