redis系列3---理解內存

理解內存

為什么要理解內存呢?redis所有的數據都存在內存中如何高效利用內存,實現用更少的內存存更多的數據,從而降低成本
如何統計內存使用?info memory可以獲取內存相關指標,如下:used_memory:redis分配器分配的內存總量used_memory_human:以可讀格式返回used_memoryused_memory_rss:從操作系統的角度顯示redis占用的物理內存總量used_memory_peak:內存使用的最大值,表示used_memory的峰值used_memory_peak_human:以可讀格式返回used_memory_peakused_memory_lua:Lua引擎所消耗的內存大小mem_fragmentation_ratio:used_memory_rss/used_memory比值,表示內存碎片率mem_allocator:redis所使用的內存分配器,默認為jemalloc(注:mem_fragmentation_ratio>1出現內存碎片,mem_fragmentation_ratio<1出現操作系統把redis內存Swap到硬盤現象)
內存消耗自身內存對象內存(sizeof(keys)+sizeof(values))緩沖內存客戶端緩沖(所有接入到redis服務器TCP連接的輸入輸出緩沖,輸入緩沖無法控制,最大空間1G,超過將斷開連接。輸出緩沖通過參數client-output-buffer-limit控制)普通客戶端(除了復制和訂閱的客戶端之外的所有連接)從客戶端(主節點會為每個從節點單獨建立一條連接用于命令復制)訂閱客戶端(當使用發布訂閱功能時,連接客戶端使用單獨的輸出緩沖區)復制積壓緩沖區(一個可重用的固定大小緩沖區用于實現部分復制功能,repl-backlog-size)AOF緩沖區(用于redis重寫期間保存最近的寫入命令)內存碎片內存分配策略(小,大,巨大)容易出現內存碎片的場景(頻繁做更新操作、大量過期鍵刪除)如何解決(數據對齊、安全重啟)子進程消耗(執行AOF/RDB重寫時redis創建的子進程內存消耗)
內存管理設置內存上限(maxmemory)動態調整內存上限(config set maxmemory 6GB)內存回收策略刪除到達過期時間的鍵對象惰性刪除(當客戶端讀取帶有超時屬性的鍵時,如果已經超過鍵設置的過期時間,會執行刪除操作并返回空,節省CPU,存在內存泄漏問題)定時任務刪除(自適應算法,鍵的過期比例、使用快慢兩種模式)內存使用達到maxmemory上限時觸發內存溢出控制策略(maxmemory-policy控制)noeviction:不會刪除任何數據,拒絕所有寫入操作并返回客戶端錯誤信息volatile-lru:根據LRU算法刪除設置了超時屬性的鍵,直到騰出足夠空間為止,如果沒有刪除的鍵,回退到noevictionallkeys-lru:根據LRU算法刪除所有鍵,直到騰出足夠空間為止allkeys-random:隨機刪除所有鍵,直到騰出足夠空間為止volatile-random:隨機刪除過期鍵,直到騰出足夠空間為止volatile-ttl:根據鍵值對象的ttl屬性,刪除最近將要過期數據,如果沒有,回退到noeviction
內存優化首先了解一下RedisObject對象type字段:表示當前對象使用的數據類型encoding字段:表示redis內部編碼類型lru字段:記錄對象最后一次被訪問的時間(object idletime {key}查看鍵的空閑時間)refcount字段:記錄當前對象被引用的次數(object refcount {key}獲取當前對象的引用)*ptr字段:與對象的數據內容有關,如果是整數,直接存儲數據,否則表示指向數據的指針有哪些具體優化手段?縮減鍵值對象(key盡可能短,value采用序列化或者壓縮算法)共享對象池(redis內部維護[0-9999]的整數對象池)注意:當設置maxmemory并啟用LRU相關淘汰策略時,redis禁止使用共享對象池;對于ziplist編碼的值對象,即使內部數據為整數也無法使用共享對象池字符串優化SDS(字符串長度、已用長度、未用長度)預分配機制(減少字符串頻繁修改操作)字符串重構編碼優化什么是編碼?具體使用哪種底層數據結構來實現string--rawembstrinthash----hashtableziplist(value<=hash-max-ziplist-value and count(field)<=hash-max-ziplist-entries)list----linkedlistziplist(value<=list-max-ziplist-value and 鏈表長度<=list-max-ziplist-entries)quicklistset-----hashtableintset(元素為整數 and 集合長度<=set-max-intset-entries)zset----skiplistziplist(value<=zset-max-ziplist-value and 有序集合長度<=zset-max-ziplist-entries)(hashtable、ziplist、linkedlist、quicklist、intset、skiplist)注意:小編碼可以轉大編碼,大不能轉小ziplist(所有數據采用線性連續的內存結構,節約內存)zlbytes:記錄整個壓縮列表所占字節長度,方便重新調整ziplist空間。類型是int-32,長度為4字節zltail:記錄距離尾節點的偏移量,方便尾節點彈出操作。類型int-32,4字節zllen:記錄壓縮鏈表節點數量,類型是int-16,2字節entry:記錄具體的節點prev_entry_bytes_length:記錄前一個節點所占空間,用于快速定位上一個節點,可實現列表反向迭代encoding:當前節點編碼和長度,前兩位表示類型,其余表示長度contents:節點的值zlend:記錄列表結尾,1字節intset(存儲有序、不重復的整數集)encoding:表示類型length:集合元素個數contents:整數數組,從小到大順序保存控制鍵的數量針對自己現在使用的模式,分析其內存消耗和可優化的地方。復制代碼

轉載于:https://juejin.im/post/5bc42e06f265da0acd20e423

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

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

相關文章

Google發布了Tensorflow Lite,用于移動電話的神經網絡庫

Google的工程副總Dave Burke宣布了一個專門針對移動電話而優化的Tensorflow新版本。\\這一新的軟件庫稱為Tensorflow Lite&#xff0c;允許開發人員在用戶的移動電話上實時地運行人工智能應用。據Burke介紹&#xff0c;該庫在設計上力求更快和更小的同時&#xff0c;依然支持最…

4. ZooKeeper 基本操作

ZooKeeper的數據模型及其API支持以下九個基本操作&#xff1a; 操作描述create在ZooKeeper命名空間的指定路徑中創建一個znodedelete從ZooKeeper命名空間的指定路徑中刪除一個znodeexists檢查路徑中是否存在znodegetChildren獲取znode的子節點列表getData獲取與znode相關的數據…

byte java byte_詳解java中的byte類型

Java中整數類型有:byte占8位, short 占16位, int占32位, long占64位Java也提供了一個byte數據類型&#xff0c;并且是基本類型中的整數類型。java byte是作為最小的數字來處理的&#xff0c;因此它的值域被定義為-128~127&#xff0c;也就是signed byte。下面這篇文章主要給大家…

zabbix 3.0.0beta1安裝-centos6.8版本

zabbix 3.0安裝 zabbix最低需要mysql 5.5 php5.3 查詢mysql版本yum list installed | grep mysql##mysql-libs.x86_64 5.1.73-5.el6_6 anaconda-CentOS-201508042137.x86_64/6.7 卸載mysqlyum remove mysql* 指定mysql源rpm -ivh http://dev.mysql.com/get/mysql-community-rel…

技術走向管理一些思考

在《IT項目管理》一書中針對IT行業定義了一個新的“工種”--多才多藝者&#xff0c;并預言未來的IT產業中多才多藝者的重要性將逐漸凸顯。多才多藝者即是具有技術背景&#xff0c;同一時候了解業務部門、能規劃和實施IT計劃、添加商業價值、培養公司內外部關系的人。 想想還認為…

npm 安裝 chromedriver 失敗的解決辦法

https://segmentfault.com/a/1190000008310875 npm install chromedriver --chromedriver_cdnurlhttp://cdn.npm.taobao.org/dist/chromedriver轉載于:https://www.cnblogs.com/chenxijywc/p/7825024.html

微軟正式發布Azure Functions 2.0

微軟正式發布Azure Functions的第二個版本&#xff0c;這是一個事件驅動的、按需計算的Azure平臺服務。與版本1相比&#xff0c;新版本的Azure Functions包含的多項特性使開發人員可以更輕松地構建可伸縮的無服務器應用程序。2016年初&#xff0c;微軟首次推出Azure Functions預…

CSS-下拉導航條

Web網站中很多時候都會出現下拉導航條&#xff0c;有的是通過CSS實現&#xff0c;有的通過JavaScript插件實現&#xff0c;其實CSS實現起來比較簡單,先來看一個簡版的下拉菜單: Html代碼通過ul列表實現: 123456789101112131415161718<ul class"nav"> <li>…

#UnityTips# 2017.11.14

hi&#xff0c;all。最近比較忙&#xff0c;所以更新也比較慢了。 今天就來和大家分享一個小Tip&#xff0c;它是關于UGUI的坑的。 使用過UGUI的朋友們都知道&#xff0c;Canvas的渲染方式有三種&#xff1a; Screen Space OverlayScreen Space CameraWorld Space其中后兩者都需…

細聊.Net Core中IServiceScope的工作方式

前言自從.Net Core引入IOC相關的體系之后&#xff0c;關于它的討論就從來沒有停止過&#xff0c;因為它是.Net Core體系的底層框架&#xff0c;你只要使用了.Net Core的時候就必然會用到它。當然關于使用它的過程中產生的問題也從來沒停止過。我對待問題的態度向來都是&#xf…

WPF 獲取鼠標屏幕位置、窗口位置、控件位置

原文:WPF 獲取鼠標屏幕位置、窗口位置、控件位置public struct POINT{public int X;public int Y;public POINT(int x, int y){this.X x;this.Y y;}}[DllImport("user32.dll")] public static extern bool GetCursorPos(out POINT lpPoint);//e.GetPosition(this);…

java 復制excel_Java 復制Excel工作表

本文歸納了關于Java如何復制Excel工作表的方法&#xff0c;按不同復制需求&#xff0c;可分為&#xff1a;1. 復制工作表1.1 在同一個工作簿內復制工作表1.2 在不同工作簿間復制工作表2. 復制指定單元格數據對于復制方法copy()&#xff0c;這里簡單整理了一個表格&#xff0c;其…

AngularDart 現已全面采用 Dart 開發

一直以來&#xff0c;Angular 2依然采用TypeScript作為主流開發語言&#xff0c;然后自動編譯成JavaScript 和 Dart。Dart開發者一直在進行Angular 2拆分&#xff0c;將其分為TypeScript/JavaScript版本和Dart版本&#xff0c;并成立了AngularDart團隊。 昨天&#xff0c;Angul…

Blazor學習之旅(4)數據共享

【Blazor】| 總結/Edison Zhou大家好&#xff0c;我是Edison。前幾天沒有發布本篇就發布了第五篇&#xff0c;屬于操作失誤哈&#xff0c;這次把第四篇補上&#xff01;本篇&#xff0c;我們來了解下在Blazor中數據是如何共享的&#xff0c;組件之間又該如何傳遞參數。關于Blaz…

Zynq7000開發系列-5(OpenCV開發環境搭建:Ubuntu、Zynq)

操作系統&#xff1a;Ubuntu14.04.5 LTS 64bit OpenCV&#xff1a;OpenCV 3.1.0、opencv_contrib gcc&#xff1a;gcc version 4.8.4 (Ubuntu 4.8.4-2ubuntu1~14.04.3) arm-xilinx-linux-gnueabi-gcc&#xff1a;gcc version 4.9.2 (Sourcery CodeBench Lite 2015.05-17) 一、U…

# 20172307 2018-2019-1 《程序設計與數據結構》第5周學習總結

20172307 2018-2019-1 《程序設計與數據結構》第5周學習總結 教材學習內容總結 查找 1.線性查找&#xff1a;從該列表頭開始依次比較每一個值&#xff0c;直至找到該目標元素。2.二分查找法&#xff1a;二分查找是從排序列表的中間開始查找&#xff0c;如果沒有在那個中間元素則…

java 生成jni_Javah生成JNI頭文件

在eclipse中建一項目&#xff0c;建一class1 packageesmart.colfile.parse;2 3 publicclassTestHello {4 static{5 System.loadLibrary("TestHello");6 }7 8 publicstaticnativevoidhello(String msg);9 10 publicstaticvoidmain(String[] args) {11 12 hello("…

IBM 的大型機 z Systems 引入 Go 語言

據 cbronline 報道&#xff0c;IBM 正把 Go 語言運用到旗下的大型機上。 IBM 將開源的 Go 語言引入到 z Systems 大型機后&#xff0c;可以給用戶多一個的選擇&#xff0c;即在大型機上使用 Linux 或基于 Go 的應用&#xff0c;同時也使大型機更加靈活。Go 語言在高并發的網絡應…

WPF-10 邏輯樹和可視化樹

我們在WPF-03 資源之Resources結尾中介紹邏輯樹和可視化樹的基本概念&#xff0c;我們這節來介紹這兩棵樹邏輯樹&#xff08;Logical Tree&#xff09;邏輯樹是由每個控件的節點組成&#xff0c;本質上就是XAML文件中的UI元素&#xff0c;我們可以通過LogicalTreeHelper類提供的…

洛谷P4364 [九省聯考2018]IIIDX(線段樹)

傳送門 題解看得……很……迷&#xff1f; 因為取完一個數后&#xff0c;它的子樹中只能取權值小于等于它的數。我們先把權值從大到小排序&#xff0c;然后記$a_i$為他左邊&#xff08;包括自己&#xff09;所有取完他還能取的數的個數。那么當取完一個點$x$的數之后&#xff0…