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

java怎麼處理高並發?

May 22, 2019 pm 04:39 PM
java

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

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

Java 中的史密斯數 Java 中的史密斯數 Aug 30, 2024 pm 04:28 PM

Java 史密斯數指南。這裡我們討論定義,如何在Java中檢查史密斯號?帶有程式碼實現的範例。

Java Spring 面試題 Java Spring 面試題 Aug 30, 2024 pm 04:29 PM

在本文中,我們保留了最常被問到的 Java Spring 面試問題及其詳細答案。這樣你就可以順利通過面試。

突破或從Java 8流返回? 突破或從Java 8流返回? Feb 07, 2025 pm 12:09 PM

Java 8引入了Stream API,提供了一種強大且表達力豐富的處理數據集合的方式。然而,使用Stream時,一個常見問題是:如何從forEach操作中中斷或返回? 傳統循環允許提前中斷或返回,但Stream的forEach方法並不直接支持這種方式。本文將解釋原因,並探討在Stream處理系統中實現提前終止的替代方法。 延伸閱讀: Java Stream API改進 理解Stream forEach forEach方法是一個終端操作,它對Stream中的每個元素執行一個操作。它的設計意圖是處

Java 中的時間戳至今 Java 中的時間戳至今 Aug 30, 2024 pm 04:28 PM

Java 中的時間戳記到日期指南。這裡我們也結合範例討論了介紹以及如何在java中將時間戳記轉換為日期。

Java程序查找膠囊的體積 Java程序查找膠囊的體積 Feb 07, 2025 am 11:37 AM

膠囊是一種三維幾何圖形,由一個圓柱體和兩端各一個半球體組成。膠囊的體積可以通過將圓柱體的體積和兩端半球體的體積相加來計算。本教程將討論如何使用不同的方法在Java中計算給定膠囊的體積。 膠囊體積公式 膠囊體積的公式如下: 膠囊體積 = 圓柱體體積 兩個半球體體積 其中, r: 半球體的半徑。 h: 圓柱體的高度(不包括半球體)。 例子 1 輸入 半徑 = 5 單位 高度 = 10 單位 輸出 體積 = 1570.8 立方單位 解釋 使用公式計算體積: 體積 = π × r2 × h (4

PHP與Python:了解差異 PHP與Python:了解差異 Apr 11, 2025 am 12:15 AM

PHP和Python各有優勢,選擇應基於項目需求。 1.PHP適合web開發,語法簡單,執行效率高。 2.Python適用於數據科學和機器學習,語法簡潔,庫豐富。

PHP:網絡開發的關鍵語言 PHP:網絡開發的關鍵語言 Apr 13, 2025 am 12:08 AM

PHP是一種廣泛應用於服務器端的腳本語言,特別適合web開發。 1.PHP可以嵌入HTML,處理HTTP請求和響應,支持多種數據庫。 2.PHP用於生成動態網頁內容,處理表單數據,訪問數據庫等,具有強大的社區支持和開源資源。 3.PHP是解釋型語言,執行過程包括詞法分析、語法分析、編譯和執行。 4.PHP可以與MySQL結合用於用戶註冊系統等高級應用。 5.調試PHP時,可使用error_reporting()和var_dump()等函數。 6.優化PHP代碼可通過緩存機制、優化數據庫查詢和使用內置函數。 7

創造未來:零基礎的 Java 編程 創造未來:零基礎的 Java 編程 Oct 13, 2024 pm 01:32 PM

Java是熱門程式語言,適合初學者和經驗豐富的開發者學習。本教學從基礎概念出發,逐步深入解說進階主題。安裝Java開發工具包後,可透過建立簡單的「Hello,World!」程式來實踐程式設計。理解程式碼後,使用命令提示字元編譯並執行程序,控制台上將輸出「Hello,World!」。學習Java開啟了程式設計之旅,隨著掌握程度加深,可創建更複雜的應用程式。

See all articles