java web實例分析
正文
在實際的工作項目中, 快取成為高並發、高效能架構的關鍵元件 ,那麼Redis為什麼可以作為快取使用呢?首先可以作為快取的兩個主要特徵:
在分層系統中處於記憶體/CPU具有存取效能良好,
- ##快取數據飽和,有良好的資料淘汰機制
- 不淘汰資料
- noeviction ,不進行資料淘汰,當快取被寫滿後,Redis不提供服務直接回傳錯誤。
- 在設定過期時間的鍵值對中,
- #volatile-random ,設定過期時間的鍵值對中隨機刪除
- volatile-ttl ,在設定過期時間的鍵值對,基於過期時間的先後進行刪除,越早過期的越先被刪除。
- volatile-lru , 基於LRU(Least Recently Used) 演算法篩選設定了過期時間的鍵值對, 最近最少使用的原則來篩選資料
- volatile-lfu ,使用LFU( Least Frequently Used ) 演算法選擇設定了過期時間的鍵值對, 使用頻率最少的鍵值對,來篩選資料。
- 在所有的鍵值對中,
- #allkeys-random, 從所有鍵值對中隨機選擇並刪除資料
- allkeys-lru, 使用LRU 演算法在所有資料中進行篩選
- allkeys-lfu, 使用LFU 演算法在所有數據中進行篩選
#其中,LRU和LFU 基於Redis的物件結構redisObject的lru和refcount屬性實現的:#Note: LRU( 最近最少使用,Least Recently Used)演算法, LRU維護一個雙向鍊錶,鍊錶的頭和尾分別表示MRU 端和LRU 端,分別代表最近最常使用的數據和最近最不常用的數據。
LRU 演算法在實際實作時,需要用鍊錶管理所有的快取數據,這會帶來額外的空間開銷。而且,當有資料被存取時,需要在鍊錶上把該資料移動到 MRU 端,如果有大量資料被訪問,就會帶來很多鍊錶移動操作,會很耗時,進而降低 Redis 快取效能。
typedef struct redisObject { unsigned type:4; unsigned encoding:4; // 对象最后一次被访问的时间 unsigned lru:LRU_BITS; /* LRU time (relative to global lru_clock) or * LFU data (least significant 8 bits frequency // 引用计数 * and most significant 16 bits access time). */ int refcount; void *ptr; } robj;
- 優先選擇 allkeys-lru演算法,將最近最常存取的資料留在快取中,提升應用程式的存取效能。
- 有頂置資料使用 volatile-lru演算法 ,頂置資料不設定快取過期時間,其他資料設定過期時間,基於LRU 規則進行篩選 。
- Cache Aside模式
- 同步:存取效能偏低,其更著重於保證資料可靠性
- Read-Throug模式
- Write-Through模式
-
Write-Behind模式
#Cache Aside模式
##查詢數據先從快取讀取數據,如果快取中不存在,則再到資料庫讀取數據,取得到數據之後更新到快取Cache中,但更新數據操作,會先去更新資料庫種的數據,然後將緩存種的資料失效。
而且Cache Aside模式會存在並發風險:執行讀取操作未命中緩存,然後查詢資料庫中取數據,數據已經查詢到還沒放入緩存,同時一個更新寫入操作讓緩存失效,然後讀取操作再把查詢到資料載入緩存,導致快取的髒資料。 Read/Write-Throug模式查詢資料和更新資料都直接存取快取服務,快取服務同步方式將資料更新到資料庫。出現髒資料的機率較低,但是就強烈依賴緩存,對快取服務的穩定性有較大要求,但同步更新會導致其效能不好。
Write Behind模式查詢資料和更新資料都直接存取快取服務,但快取服務使用非同步方式地將資料更新到資料庫(透過非同步任務) 速度快,效率會非常高,但是資料的一致性比較差,還可能會有資料的遺失情況,而實現邏輯也較為複雜。
在實際專案開發中根據實際的業務場景需求來進行選擇快取模式。那了解上述後,為什麼我們的應用程式需要使用到redis快取呢? 在應用程式使用Redis快取可以提高系統效能和並發,主要體現在- 高效能:基於記憶體查詢,KV結構,簡單邏輯運算
- 高並發: Mysql 每秒只能支援2000左右的請求,Redis輕鬆每秒1W以上。讓80%以上查詢走緩存,20%以下查詢走資料庫,能讓系統吞吐量有很大的提高
- ##快取與資料庫雙寫不一致
- 快取雪崩: Redis 快取無法處理大量的應用請求,轉移到資料庫層導致資料庫層的壓力激增;
- ##快取穿透:訪問資料不存在在Redis快取中和資料庫中,導致大量存取穿透快取直接轉移到資料庫導致資料庫層的壓力激增;
- 快取擊穿:快取無法處理高頻熱點數據,導致直接高頻存取資料庫導致資料庫層的壓力激增;
- 快取與資料庫資料不一致
只讀快取(Cache Aside模式)
對於只讀快取(Cache Aside模式)
, 讀取操作都會發生在快取中,資料不一致只會發生在刪改操作上(新增操作不會,因為新增只會在資料庫處理),當發生刪改操作時,快取將資料中標誌為無效和更新資料庫。因此在更新資料庫和刪除快取值的過程中,無論這兩個操作的執行順序誰先誰後,只要有一個操作失敗了就會出現資料不一致的情況。
以上是java web實例分析的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

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

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

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

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

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

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

PHP適合web開發,特別是在快速開發和處理動態內容方面表現出色,但不擅長數據科學和企業級應用。與Python相比,PHP在web開發中更具優勢,但在數據科學領域不如Python;與Java相比,PHP在企業級應用中表現較差,但在web開發中更靈活;與JavaScript相比,PHP在後端開發中更簡潔,但在前端開發中不如JavaScript。

PHP和Python各有優勢,適合不同場景。 1.PHP適用於web開發,提供內置web服務器和豐富函數庫。 2.Python適合數據科學和機器學習,語法簡潔且有強大標準庫。選擇時應根據項目需求決定。

PHPhassignificantlyimpactedwebdevelopmentandextendsbeyondit.1)ItpowersmajorplatformslikeWordPressandexcelsindatabaseinteractions.2)PHP'sadaptabilityallowsittoscaleforlargeapplicationsusingframeworkslikeLaravel.3)Beyondweb,PHPisusedincommand-linescrip

PHP成為許多網站首選技術棧的原因包括其易用性、強大社區支持和廣泛應用。 1)易於學習和使用,適合初學者。 2)擁有龐大的開發者社區,資源豐富。 3)廣泛應用於WordPress、Drupal等平台。 4)與Web服務器緊密集成,簡化開發部署。

PHP適用於Web開發和內容管理系統,Python適合數據科學、機器學習和自動化腳本。 1.PHP在構建快速、可擴展的網站和應用程序方面表現出色,常用於WordPress等CMS。 2.Python在數據科學和機器學習領域表現卓越,擁有豐富的庫如NumPy和TensorFlow。
