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丰富的数据结构之旅,当然先从最简 ...
随机推荐
- xml转换成数组array
直接上代码,成功转换 if($data){ //返回来的是xml格式需要转换成数组再提取值,用来做更新 $startnum = strpos($data,"<xml>" ...
- WinSocket简单聊天程序客户端
#pragma comment(lib,"Ws2_32.lib") #include <stdio.h> #include <Winsock2.h> SOC ...
- 2013 ACM/ICPC Asia Regional Changsha Online - J
原题戳这里. 题意: 有一未知列数a1,a2,a3.....an, 已知s[i]=a[i-1]+a[i]+a[i] (1<i<n) s[1]=a[1]+a[2]; s[n]=a[n-1] ...
- SQLServer XXX IS NOT NULL
SQLServer中不能使用像Java和C#中的 XXX!=null 这种用法, 使用上面的用法返回值永远是False False False 正确的用法应该是--> XXXis not ...
- IIS 7.0、IIS 7.5 和 IIS 8.0 使用的 HTTP 状态代码【转载自微软官方】
HTTP 状态代码 本部分描述 IIS 7.0.IIS 7.5 和 IIS 8.0 使用的 HTTP 状态代码. 注意 本文不会列出 HTTP 规范中所述的每个可能的 HTTP 状态代码.本文只包括 ...
- Mysql Event 自动分表
create table TempComments Like dycomments; 上述 SQL语句创建的新表带有原表的所有属性,主键,索引等. 自动分表怎么做呢? 使用上述语句自动创建分表. 那么 ...
- sqlserver 常用到的架构相关的表芝士
“SELECT COLUMN_NAME,TABLE_NAME FROM INFORMATION_SCHEMA.columns WHERE COLUMN_NAME='WareHouse_Code'” 如 ...
- 多种效果进度指示层效果iOS源码项目
该源码是一个多种效果进度指示层效果源码案例,源码KVNProgress,KVNProgress提供多种效果的进度指示层,有半透明效果,也支持全屏显示.指示层还高度支持自定义,可以按自己的需求定制.效果 ...
- The as! Operator
Prior to Swift 1.2, the as operator could be used to carry out two different kinds of conversion, de ...
- xpath定位实列
这次将讲Xpath定位! 什么是Xpath: Path就是路径,xpath也类似,就像 在DOS中 D:\Auto\jack. Xpath的使用: 1:在火狐下载 FirePath 插件(图1),然后 ...