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丰富的数据结构之旅,当然先从最简 ...
随机推荐
- go的基础数据类型
一.基础数据类型 在go语言中,数据类型用于申明函数和变量 go语言的类型 数据类型 描述 布尔型 布尔型值的只能是true 和 false ,例如 var b bool = true, 布尔型值声明 ...
- iOS 代理设计模式
在项目中经常会用到代理的设计模式,这是iOS中一种消息传递的方式,也可以通过这种方式传递一些参数. 在项目中,刚开始我是用一些代理来传递参数的,但是慢慢觉得代理的代码比较block多,所以就更多的使用 ...
- Nmap linux端口扫描神器
#简介 Nmap亦称为Network Mapper(网络映射)是一个开源并且通用的用于Linux系统/网络管理员的工具.nmap用于探查网络.执行安全扫描.网络核查并且在远程机器上找出开放端口.它可以 ...
- 分类(Category)的本质 及其与类扩展(Extension) /继承(Inherit)的区别
1.分类的概念 分类是为了扩展系统类的方法而产生的一种方式,其作用就是在不修改原有类的基础上,为一个类扩展方法,最主要的是可以给系统类扩展我们自己定义的方法. 如何创建一个分类?↓↓ ()Cmd+N, ...
- 阶乘问题-----sum随变量改变而改变
- JAVA;使用java.awt.Image的不稳定性
在使用awt的image时候,不是能时时获取到图像的宽和高, GetWidth()函数偶尔得到的值为-1,暂时没有找到解决方法. 代码: public class picture extends JF ...
- 递归删除List元素
public List<Redenvelope> DeleteList(List<Redenvelope> list) { foreach (var item in list) ...
- jq 替换DOM layeui 不刷新
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...
- printf 打印较长字符
- 分别用for循环,while do-while以及递归方法实现n的阶乘!
分别用for循环,while do-while以及递归方法实现n的阶乘! 源码: package book;import java.util.Scanner;public class Access { ...