redis之Hash存储与String存储内存消耗对照
存储对象User
String存储方式:
SET media:1155315 939
GET media:1155315
> 939
String结构存储该对象
User243 243600
| 存储量 | 使用内存(KB) | 使用时间(毫秒) | 使用cpu |
|---|---|---|---|
| 100 | 30.72 | 2983 | |
| 100 | 30.72 | 1224 | |
| 100 | 40.96 | 2638 | |
| 100 | 40.96 | 1543 | |
| 100 | 40.96 | 3335 |
| 4487 | 1934.62 | 21760(21.76秒) | 0.05 |
| 4487 | 1934.59 | 21732(21.732秒) | 0.05 |
| 1000000 | 84.042MB | 70.672分(单线程) |
String结构存储该对象
| 存储量 | 使用内存(KB) | 使用时间(秒) | 使用cpu |
| 100 | 30.72 | 0.2983 | |
| 100 | 30.72 | 0.1224 | |
| 100 | 40.96 | 0.2638 | |
| 100 | 40.96 | 0.1543 | |
| 100 | 40.96 | 0.3335 | |
| 4487 | 1934.62 | 21.76 | |
| 4487 | 1934.62 | 21.732 | |
| 1000000 | 84.042MB | 70.672(分钟) |
Hash结构存储该对象
| 存储量 | 使用内存(KB) | 使用时间(秒) | 使用cpu |
| 100 | 367.76 | 0.454 | |
| 100 | 37.37 | 0.458 | |
| 50.50 | 0.461 | ||
| 100 | 40.44 | 0.467 | |
| 100 | 35.50 | 0.489 | |
| 4487 | 1805.1 | 21.729 | |
| 4487 | 1844.23 | 21.712 | |
| 4487 | 1844.23 | 21.778 | |
| 1000000 | 68.70MB |
HSET "mediabucket:1155" "1155315" "939"
HGET "mediabucket:1155" "1155315"
> "939"
| 存储量 | 使用内存(KB) | 使用时间(毫秒) | 使用cpu |
|---|---|---|---|
| 100 | 367.76 | 454 | |
| 100 | 37.37 | 458 | |
| 100 | 50.50 | 461 | |
| 100 | 40.44 | 467 | |
| 100 | 35.50 | 489 |
| 4487 | 1805.1 | 21729 | 0.06 |
| 4487 | 1844.23 | 21712 | 0.05 |
| 4487 | 1844.23 | 21778 |
| 1000000 | 0 | 68.70MB | |
Hash结构继续优化
类似
HSET "1155" "315" "939"
HGET "1155" "315"
> "939"
| 存储量 | 使用内存(KB) | 使用时间(毫秒) | 使用cpu |
|---|---|---|---|
| 100 | 367.76 | 454 | |
| 100 | 37.37 | 458 | |
| 100 | 50.50 | 461 | |
| 100 | 40.44 | 467 | |
| 100 | 35.50 | 489 |
| 4487 | 1803.29 | 21879 | 0.06 |
| 4487 | 1842.43 | 21931 | 0.05 |
參考文章:
http://www.searchdatabase.com.cn/showcontent_54724.htm
节约内存:Instagram的Redis实践
redis之Hash存储与String存储内存消耗对照的更多相关文章
- StackExchange.Redis 之 hash 类型示例
StackExchange.Redis 的组件封装示例网上有很多,自行百度搜索即可. 这里只演示如何使用Hash类型操作数据: // 在 hash 中存入或修改一个值 并设置order_hashkey ...
- redis内存消耗详解
Redis所有的数据都存在内存中,相对于廉价的硬盘,内存资源还是比较昂贵的,因此如何高效利用redis内存变得非常重要. 内存消耗分析 管理内存的原理和方法 内存优化技巧 一.内存消耗 理解redis ...
- 一文了解 Redis 内存监控和内存消耗
Redis 是一种内存数据库,将数据保存在内存中,读写效率要比传统的将数据保存在磁盘上的数据库要快很多.所以,监控 Redis 的内存消耗并了解 Redis 内存模型对高效并长期稳定使用 Redis ...
- ***Redis hash是一个string类型的field和value的映射表.它的添加、删除操作都是O(1)(平均)。hash特别适合用于存储对象
http://redis.readthedocs.org/en/latest/hash/hset.html HSET HSET key field value (存一个对象的时候key存) 将哈希 ...
- Redis学习03——存储字符串(String)
--------------------- 作者:愤怒的小明 来源:CSDN 原文:https://blog.csdn.net/qiwenmingshiwo/article/details/78118 ...
- 直接在安装了redis的Linux机器上操作redis数据存储类型--String类型
一.概述: 字符串类型是Redis中最为基础的数据存储类型,它在Redis中是二进制安全的,这便意味着该类型可以接受任何格式的数据,如JPEG图像数据或Json对象描述信息等.在Redis中字符串类型 ...
- 一个 -100.01 的double 在内存中怎么存储的. 一个中文String 在内存中占多少直接 utf-8 / GBK
一.-100.01 的double 在内存中怎么存储的 double双精度数据类型存储格式IEEE 双精度格式为8字节64位,由三个字段组成:52 位小数 f : 11 位偏置指数 e :以及 1 位 ...
- redis和ehcache的区别,存储方式(各属于内存还是外存)
ehcache属于内存存储,redis的缓存属于内存存储,redis的持久文件属于外存存储: redis是通过socket访问到缓存服务,效率比ecache低,比数据库要快很多,处理集群和分布式缓存方 ...
- Redis系列-存储篇string主要操作命令
Redis系列-存储篇string主要操作命令 通过上两篇的介绍,我们的redis服务器基本跑起来.db都具有最基本的CRUD功能,我们沿着这个脉络,开始学习redis丰富的数据结构之旅,当然先从最简 ...
随机推荐
- [Apple开发者帐户帮助]三、创建证书(2)创建开发者ID证书
您可以使用开发人员帐户或Xcode 创建最多五个开发者ID应用程序证书和最多五个开发人员ID安装程序证书.(要在Xcode中创建开发者ID证书,请转到Xcode帮助中的管理签名证书.) 所需角色:帐户 ...
- Django day14(一) cookie
一: Cookie 1. Cookie是什么?存储在客户端浏览器上的键值对 2. 原理: 是服务器产生,发给客户端浏览器,浏览器保存起来,下次发请求,会携带这个键值对到服务器 4. Cookie的覆 ...
- pjax使用小结
简介 虽然传统的ajax方式可以异步无刷新改变页面内容,但无法改变页面URL,因此有种方案是在内容发生改变后通过改变URL的hash的方式获得更好的可访问性(如https://liyu365.gith ...
- MySQL学习笔记之右连接
MySQL的右连接 #右连接,以右表为基表 select course.stuid,course.stuname,sex,course,city from class1 right join cour ...
- windbg将调试信息保存到文本文件
在跟踪一些出现频率较低的问题时,有时候需要长时间调试,但是在在输出信息太多时可能前面的日志会被清空,为避免这种情况,可以将输出日志记录到文本文件以备查看. 1. 可以在启动时直接用带 -logo的命令 ...
- SQL学习--Select(一)TOP、派生表、连接、谓词
TOP关键字 WITH TIES t.title,sum(s.qty)as totalSales from sales s left join titles t on s.title_id=t.tit ...
- CSS画各种二维图形
1.效果 2.源码 <%@ page contentType="text/html;charset=UTF-8" language="java" %> ...
- 华为 荣耀 等手机解锁BootLoader
下载工具按提示操作即可 链接:https://pan.baidu.com/s/1qZezd1q 密码:8pad 备用链接:https://pan.baidu.com/s/1nwv0heD
- 用JSP实现动态交互
一.什么是JSP? 1.在HTML中嵌入Java脚本代码 2.由应用服务器中的JSP引擎来编译和执行嵌入的Java脚本代码 3.然后将生成的整个页面信息返回给客户端 二.为什么需要基于B/S技术的 ...
- 4、scala数组
1.Array 2.ArrayBuffer 3.遍历Array和ArrayBuffer 4.数组常见操作 1. Array Scala中,array代表的含义与java类似,也是长度不可改变的数组. ...