首頁 > Java > Java面試題 > java面試——高並發處理

java面試——高並發處理

王林
發布: 2020-11-23 16:06:12
轉載
3749 人瀏覽過

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、快取

具體接觸過的快取機制是hibernate的快取機制。為了避免每次都向資料庫中取得數據,我們把用戶常常訪問到的數據放到內存中,甚至緩存十分大的時候我們可以把內存中的緩存放到硬碟中。還有進階的分散式快取資料庫使用,都可以增加系統的抗壓力。

(更多相關面試題推薦:java面試題目及答案

#5、分批傳送

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

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

6、資料庫叢集

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

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

7、DB最佳化

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

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

c、表格欄位的類型選擇要恰當

包含欄位的長度、類型等,要根據實際儲存的資料進行選擇,長度不要過長,否則會影響效率。

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

e、在資料庫操作上

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

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

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

相關推薦:java入門教學

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

相關標籤:
來源:csdn.net
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板