查看redis aof內存_Redis持久化問題定位與優化技巧

今天主要分享繼Redis持久化方式RDB、AOF之后的一些常用的Redis問題定位于優化方式。這里主要CPU、內存、磁盤在三個維度去分析問題!

Fork操作

當Redis做RDB或AOF重寫時,一個必不可少的操作就是執行fork操作創建子進程,對于大多數操作系統來說fork是個重量級操作

雖然fork創建的子進程不需要拷貝父進程的物理內存空間,但是會復制父進程的空間內存頁表。例如對于10GB的Redis進程,需要復制大約20MB的內存頁表,因此fork 操作耗時跟進程總內存量息息相關,如果使用虛擬化技術,特別是Xen虛擬 機,fork操作會更耗時

  • 在做 RDB 或 AOF 重寫時, fork 是必不可少的
  • 對于大多數操作系統來說, fork 是個重量級錯誤
  • fork 會復制符進程的空間內存頁表
  • 如果使用虛擬化技術, 特別是 Xen 虛擬機, fork 操作會更耗時

fork 耗時問題定位:

  • 高流量的 Redis 實例 ops 可達5萬以上
  • 正常情況 fork 耗時應該是每 GB 消耗 20ms 左右
  • 可以用 info stats 命令查看 latest_fork_usec 指標, 獲取最近一次 fork 操作耗時, 單位微秒

如何改善 fork 操作的耗時:

  • 優先使用物理機或者高效支持 fork 操作的虛擬化技術, 避免使用 Xen
  • 控制 Redis 實例最大可用內存, fork 耗時跟內存量成正比, 線上建議每個 Redis 實例內存控制在 10GB 以內
  • 合理配置 Linux 內存分配策略, 避免物理內存不足導致 fork 失敗, 具體細節見12.1節 “Linux 配置優化”
  • 降低 fork 操作的頻率, 如適度放寬 AOF 自動觸發時機, 避免不必要的全量復制等

子進程開銷進程與優化

子進程負責AOF或者RDB文件的重寫,它的運行過程主要涉及CPU、內存、硬盤三部分的消耗

CPU

  • CPU 開銷分析。子進程負責把進程內的數據分批寫入文件, 這個過程屬于 CPU 密集操作, 通常子進程對單核 CPU 利用率接近90%
  • CPU 消耗優化。Redis 是 CPU 密集型服務, 不要做綁定單核 CPU 操作。由于子進程非常消耗 CPU, 會和父進程產生單核資源競爭.
  1. 不要和其他 CPU 密集型服務部署在一起, 造成 CPU 過度競爭
  2. 如果部署多個 Redis 實例, 盡量保證同一時刻只有一個子進程執行重寫工作, 具體細節見5.4節多實例部署

硬盤

  • 硬盤開銷分析

子進程主要職責是把 AOF 或者 RDB 文件寫入硬盤持久化。勢必造成硬盤寫入壓力。根據 Redis 重寫 AOF/RDB 的數據量, 結合系統工具如 sar、iostat、iotop 等, 可分析出重寫期間硬盤負載情況

  • 硬盤開銷優化
    • 不要和其他高硬盤負載的服務部署在一起。如: 存儲服務、消息隊列服務等
    • AOF 重寫時會消耗大量硬盤 IO, 可以開啟配置 no-appendfsync-on-rewrite, 默認關閉。表示在 AOF 重寫期間不做 fsync 操作
    • 當開啟 AOF 功能的 Redis 用于高流量寫入場景時, 如果使用普通機械磁盤, 寫入吞吐一般在 100MB/s 左右, 這時 Redis 實例的瓶頸主要在 AOF 同步硬盤上
    • 對于單機配置多個 Redis 實例的情況, 可以配置不同實例分盤存儲 AOF 文件, 分攤硬盤寫入壓力

配置 no-appendfsync-on-rewrite=yes 時, 在極端情況下可能丟失整個 AOF 重寫期間的數據,需要根據數據安全性決定是否配置

內存

  • 內存消耗分析

子進程通過 fork 操作產生, 占用內存大小等同于父進程, 理論上需要兩倍的內存來完成持久化操作, 但 Linux 有寫時復制機制 (copy-on-write)。父子進程會共享相同的物理內存頁, 當父進程處理寫請求時會把要修改的頁創建副本, 而子進程在 fork 操作過程中共享整個父進程內存快照。

  • 內存消耗監控
    • RDB 重寫: 被修改的內存頁可以等價認為 RDB 重寫的消耗
    • AOF 重寫: 被修改的內存頁 + AOF 重寫緩沖區
  • 內存消耗優化
    • 如果部署多個 Redis 實例, 盡量保證同一時刻只有一個子進程在工作
    • 避免在大量寫入時做子進程重寫操作, 這樣將導致父進程維護大量頁副本, 造成內存消耗

Transparent Huge Pages(THP) 是 Linux kernel 在2.6.38增加的功能, 支持 huge page (2MB) 頁分配, 會降低 fork 速度, 默認開啟. 當開啟時, 在 fork 后會大幅增加重寫期間父進程的內存消耗, 建議關閉:

sudo?echo?never>/sys/kernel/mm/transparent_hugepage/enabled

AOF追加阻塞

當開啟AOF持久化時,常用的同步硬盤的策略是everysec,用于平衡性 能和數據安全性。對于這種方式,Redis使用另一條線程每秒執行fsync同步 硬盤。當系統硬盤資源繁忙時,會造成Redis主線程阻塞!如下圖所示

408b61fbe03f3f744723143bd0b6919d.png

阻塞流程分析

  • 如果距上次同步成功時間在2秒內,主線程直接返回
  • 如果距上次同步成功時間超過2秒,主線程將會阻塞,直到同步操作完 成。
    • 主線程負責寫入AOF緩沖區
    • AOF線程負責每秒執行一次同步磁盤操作,并記錄最近一次同步時 間
    • 主線程負責對比上次AOF同步時間:

通過對AOF阻塞流程可以發現兩個問題

  • everysec配置最多可能丟失2秒數據,不是1秒
  • 如果系統fsync緩慢,將會導致Redis主線程阻塞影響效率

AOF阻塞問題定位

  • 每當發生AOF追加阻塞事件發生時,在info Persistence統計中, aof_delayed_fsync指標會累加,查看這個指標方便定位AOF阻塞問題。
  • AOF同步最多允許2秒的延遲,當延遲發生時說明硬盤存在高負載問 題,可以通過監控工具如iotop,定位消耗硬盤IO資源的進程
  • 發生 AOF 阻塞時, Redis 輸出如下日志, 用于記錄 AOF fsync 阻塞導致拖慢 Redis 服務的行為
Asynchronous?AOF?fsync?is?taking?too?long?(disk?is?busy).?Writing?the?AOF?bufferwithout?waiting?for?fsync?to?complete,?this?may?slow?down?Redis
  • 每當發生 AOF 追加阻塞事件發生時, 在info Persistence 統計中, aof_delayed_fsync 指標會累加, 查看這個指標方便定位 AOF 阻塞問題
  • AOF 同步最多允許2秒的延遲, 當延遲發生時說明硬盤存在高負載問題, 可以通過監控工具如 iotop, 定位消耗硬盤 IO 資源的進程

更多原創技術分享,關注公眾號:碼農架構

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/533375.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/533375.shtml
英文地址,請注明出處:http://en.pswp.cn/news/533375.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

mysql新增陣列df_DF學Mysql(三)——索引操作

概要:數據庫對象索引其實與書的目錄非常相似,主要是為了提高從表中檢索數據的速度。由于數據存儲在數據庫表中,所以索引是創建在數據庫表對象上的,由表中的一個字段或多個字段生成的鍵組成,這些鍵存儲在數據結構(B-樹或…

python本地瀏覽器注入js_PyQt5內嵌瀏覽器注入JavaScript腳本實現自動化操作的代碼實例...

概要應同學邀請,演示如何使用 PyQt5 內嵌瀏覽器瀏覽網頁,并注入 Javascript 腳本實現自動化操作。下面測試的是一個廉價機票預訂網站(http://www.flyscoot.com/),關鍵點如下使用 QWebEngineView 加載網頁,并顯示進度。在默認配置(…

python裝好了怎么啟動車_【填空題】Python安裝好后,可以直接在CMD命令行下輸入( )命令, 可啟動交互式編程,提示窗口如下:...

傾斜巖層的產狀要素是用巖層層面的()。A.傾角B.走向C.范圍D.傾向E.表面積采用深層攪拌法進行地基加固處理,其適用條件為()。A.砂礫石松軟地基B.松散砂地基C.黏土軟弱地基根據《建筑工程建筑面積計算規則》,下列關于建筑物雨篷結構的建筑面積計算&#xf…

windows設置mysql使用率_Windows下配置Mysql

這里說的配置Mysql,是在安裝時進行的,請先查看:Windows平臺下安裝Mysql緊接上文,安裝完成后將配置選項打上對勾,按下“Finish”,出現下面的界面,這里有一個很好的功能,mysql配置向導…

mysql 云無憂ps教程_華為云數據庫MySQL一鍵開通讀寫分離,無憂應對企業業務高峰情景...

業務大促,訂單暴增,網站流量暴漲幾倍,數據庫服務器容量又要扛不住了,眼睜睜看著生意白白溜走,再苦逼也無法解決,“腫”么辦?別擔心,一鍵開通讀寫分離,而且只需一個連接地…

mysql實體監聽器_GitHub - langjiangit/spring-boot-starter-mysql-binlog: mysql的binlog監聽器

mysql binlog監聽器前置操作1.查看mysql是否開啟binlogshow variables like log_bin;2.查看是否使用row格式的binlogshow variables like binlog_format;3.如果以上都不是請修改mysql的配置文件添加或者修改如下內容#配置binlog存放路徑log-binE://mysql//binlog//mysql-bin#bi…

python 基因序列提取_科學網—簡單的Python腳本提取對應位置基因序列(fasta文件) - 王彬忠的博文...

最近,用Python腳本提取,在基因號已知,位置已知條件下,相對應位置的基因序列時發現,這樣很簡單但是很實用的腳本,在網上卻比較難找。而且,能被找到的腳本,相對于具有初級編程能力的人…

python不能安裝在中文_無法在Python上安裝表

我一直收到錯誤Command "python setup.py egg_info" failed with error code 1 in C:\Users\HP\AppData\Local\Temp\pip-install-sv33cp8y\tables\當嘗試使用^{pr2}$我試過了pip install --upgrade setuptools還有很多其他的東西,但還是不能讓它發揮作用。…

python是強定義語言嗎_python是強類型語言嗎

強弱是對類型而言的。強類型,你有一個值之后這個值是什么類型是確定,比如n1,n的類型是確定的(字符串),因此你不能在Python做n3 mn1運算。而弱類型就不是這樣的,值的類型可以在需要的時候再去確定,比如PHP里…

mysql給字段添加描述_用sql 語句給字段添加描述

用sql 語句給字段添加描述IF not exists(SELECT * FROM ::fn_listextendedproperty (NULL, user, dbo, table, strTableName, column, strColumnName))BEGINexec sp_addextendedpropertyMS_Description, strColumnDesc , user, dbo, table,strTableName, column, strColumnName…

深入java核心_Java核心(五)深入理解BIO、NIO、AIO

導讀:本文你將獲取到:同/異步 阻/非阻塞的性能區別;BIO、NIO、AIO 的區別;理解和實現 NIO 操作 Socket 時的多路復用;同時掌握 IO 最底層最核心的操作技巧。BIO、NIO、AIO 的區別是什么?同/異步、阻/非阻塞…

java反射 獲取參數類型_Java反射帶參構造創建對象時如何自動轉換參數類型

需求是這樣的:有一個類,類的路徑知道,例如是com.xx.xx.xx其中有不同類型的成員變量(個數未知),有對應的setter和getter方法,有一個無參構造和一個全參構造。現在需要用反射機制...需求是這樣的:有一個類&am…

java的樂趣_分享java帶來的快樂

2013年9月17日#2011年7月18日#function reportError(sMessage, sUrl, sLine) {var str "";str " 錯誤信息:" sMessage "\n";str " 錯誤地址:" sUrl "\n";str " 錯誤行數:" sLine "\n";str &…

java arraylist底層實現原理_ArrayList和LinkedList底層原理

ArrayList和LinkedList都是List的實現類,是在日常開發中經常被使用到的兩個集合,我們來結合源碼看下兩個集合的不同之處。先來看下ArrayList的源碼:// 默認的初始化大小private static final int DEFAULT_CAPACITY 10;ArrayList的底層數數組…

java ee jaas_java-ee – Tomcat-Jaas – 如何檢索主題?

i knew that and it works, but I need to retrieve subject to get also roleprincipal不幸的是,它在Java EE中的工作方式不同. JAAS主題只是一個“主要包”,其中哪些代表用戶/調用者主體和/或角色主體根本不是標準化的.每個其他容器在這里做不同的事情. Javadoc for Tomcat’…

java jive歌詞_Java Jive_Manhattan Transfer with Phil Collins_高音質在線試聽_Java Jive歌詞|歌曲下載_酷狗音樂...

Manhattan Transfer with Phil Collins - Java Jive[id:$00000000][ar:曼哈頓行者爵士][ti:Java Jive (LP Version)][by:][hash:99bf26cac4ad13e15925a56eb724027f][al:][sign:][qq:][total:0][offset:0][00:00.05]The Manhattan Transfer - Java Jive[00:10.57]I …

java 3_Java 3 (Java的數據類型)

Java的數據類型主要內容:1Java數據類型的分類2.8種基本數據類型3.理解引用類型的特點一、什么是數據類型?計算機語言將數據按性質進行分類,每一類稱為一種數據類型;數據類型定義了數據的性質、取值范圍、存儲方式、對數據所能進行…

java快捷鍵 --_Java中的快捷方式“或分配”(| =)運算符

如果是關于可讀性,我就有了將測試數據與測試邏輯分離的概念。代碼示例:// declare dataDataType [] dataToTest new DataType[] {defaultStock,defaultWholesale,defaultRetail,defaultDelivery}// define logicboolean checkIfAnyNegative(DataType []…

tcp網絡通信教程 java_基于java TCP網絡通信的實例詳解

JAVA中設計網絡編程模式的主要有TCP和UDP兩種,TCP是屬于即時通信,UDP是通過數據包來進行通信,UDP當中就會牽扯到數據的解析和傳送。在安全性能方面,TCP要略勝一籌,通信過程中不容易出現數據丟失的現象,有一…

java博客論壇設計報告_javaweb課程設計報告個人博客網站的實現(Java).doc

javaweb課程設計報告個人博客網站的實現(Java)項目名稱: 個人博客網站的實現(Java) 學生姓名:學 號:班 級:指導教師:2014年12月23日目錄1 緒論11.1系統應用意義11.2主要設計任務11.3開發及運行環境11.3.1 JSP的基礎——…