什麼是Redis記憶體碎片?
作業系統的剩餘空間總量足夠,但申請一塊N位元組連續位址的空間時,剩餘記憶體空間中沒有大小為N位元組的連續空間,那麼這些剩餘記憶體空間中,小於N位元組的連續記憶體空間就是記憶體碎片。
Redis記憶體碎片是如何形成的?
記憶體碎片形成有內部原因和外部原因:
內部原因:記憶體分配器的分配策略決定作業系統無法做到「按需分配」。
Redis使用libc、jemalloc、tcmalloc多種記憶體分配器來分配內存,預設使用jemalloc。
記憶體分配器是按照固定大小來分配記憶體空間,而不是完全按照應用程式申請的記憶體大小來分配。
以jemalloc為例,是依照一系列固定的大小劃分記憶體空間,例如8位元組、16位元組、32位元組、...、2KB、4KB等。 Jemalloc會分配與程式申請記憶體最接近的固定大小的空間。
外部原因:鍵值對大小不一樣,且鍵值對可以被修改和刪除。
Redis申請記憶體空間分配時,對於大小不一的記憶體空間需求,記憶體分配器依照固定大小分配記憶體空間,分配的記憶體空間一般都會比申請的記憶體空間大一些,這會產生一定的記憶體碎片。
鍵值對會被修改和刪除,會導致空間的擴容和釋放。
如何判斷Redis是否有記憶體碎片?
DAS透過Redis提供的INFO命令,查詢記憶體使用的詳細信息,命令如下:
INFO memory # Memory used_memory:350458970752 used_memory_human:326.39G used_memory_rss:349066919936 used_memory_rss_human:325.09G … mem_fragmentation_ratio:1.00
used_memory:表示Redis為了保存數據實際申請使用的記憶體空間。
used_memory_rss:表示作業系統實際分配給Redis的實體記憶體空間,其中包含了記憶體空間碎片。
mem_fragmentation_ratio指當前Redis的記憶體碎片率。計算公式:mem_fragmentation_ratio=used_memory_rss/used_memory
mem_fragmentation_ratio大於等於1但小於等於1.5,這種情況是合理的。
mem_fragmentation_ratio大於1.5,表示記憶體碎片率已經超過了50%。
如何清理記憶體碎片?
一個「簡單粗暴」的方法是重啟Redis實例。但是這個方法會帶來兩個後果:
如果Redis中的資料沒有持久化,資料會遺失;
無論Redis數據是否被持久化,恢復資料時都需採用AOF或RDB方式,而復原所需時間取決於AOF或RDB檔案的大小。且如果只有一個Redis實例,則復原階段無法提供服務。
那有沒有更好的方法呢?有的,從4.0-RC3版本以後,Redis本身提供了一種記憶體碎片自動清理的方法。
記憶體碎片自動清理
記憶體碎片清理,簡單來說,就是「搬家讓位,合併空間」。
當有資料把一塊連續的記憶體空間分割成好幾塊不連續的空間時,作業系統會把資料拷貝到另外,而原來不連續的記憶體空間就變成連續的記憶體空間了。
但是碎片清理是有代價的。移動多份資料到新位置並釋放原有空間是作業系統必須做的,但這個過程會花費時間。另外在資料拷貝時,會阻塞Redis,降低效能。
如何緩解這個問題?
Redis專門為自動記憶體碎片清理機制提供參數設定。可以透過設定參數,來控制碎片清理的開始和結束時機,以及佔用的CPU比例,從而減少碎片清理對Redis請求處理的效能影響。
首先,開啟自動記憶體碎片清理:
config set activedefrag yes
然後,設定觸發記憶體清理的條件:
active- defrag-ignore-bytes 100mb:表示記憶體碎片的位元組數達到100MB時,開始清理;
- ##active-defrag-threshold-lower 10:表示記憶體碎片空間佔作業系統分配給Redis的總空間比例達到10%時,開始清理。
- active-defrag-cycle-min 25: 表示自動清理過程所用CPU時間的比例不低於25%,保證清理能正常進行;
- #active-defrag-cycle-max 75:表示自動清理過程所用CPU時間的比例不高於75%,一旦超過,就停止清理,從而避免在清理時,大量的記憶體拷貝阻塞Redis,導致反應延遲升高。 #
以上是怎麼清理Redis記憶體碎片的詳細內容。更多資訊請關注PHP中文網其他相關文章!

Redis是现在最热门的key-value数据库,Redis的最大特点是key-value存储所带来的简单和高性能;相较于MongoDB和Redis,晚一年发布的ES可能知名度要低一些,ES的特点是搜索,ES是围绕搜索设计的。

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了关于redis的一些优势和特点,Redis 是一个开源的使用ANSI C语言编写、遵守 BSD 协议、支持网络、可基于内存、分布式存储数据库,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了Redis Cluster集群收缩主从节点的相关问题,包括了Cluster集群收缩概念、将6390主节点从集群中收缩、验证数据迁移过程是否导致数据异常等,希望对大家有帮助。

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了Redis实现排行榜及相同积分按时间排序,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,希望对大家有帮助。

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了关于原子操作中命令原子性的相关问题,包括了处理并发的方案、编程模型、多IO线程以及单命令的相关内容,下面一起看一下,希望对大家有帮助。

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了bitmap问题,Redis 为我们提供了位图这一数据结构,位图数据结构其实并不是一个全新的玩意,我们可以简单的认为就是个数组,只是里面的内容只能为0或1而已,希望对大家有帮助。

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了Redis实现排行榜及相同积分按时间排序,本文通过实例代码给大家介绍的非常详细,下面一起来看一下,希望对大家有帮助。

redis error就是redis数据库和其组合使用的部件出现错误,这个出现的错误有很多种,例如Redis被配置为保存数据库快照,但它不能持久化到硬盘,用来修改集合数据的命令不能用。


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

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

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。