redis day02 下
位图:是二进制数据(0101101010)2^32
强势点:
01_login :101110(比如:第一天登录,二天没登录)
传统的字符串解决方案中 记录用户登录日期 统计堪忧
01_login_20200206: 1
01_login_20200207: 0
传统的list解决方案中 统计堪忧,查找堪忧
01_login :[20200206, 20200208](统计那天登录了)
SETBIT kk3 8 1(第8位是1,其他为0)
00000001
Hash散列数据类型(field和value必须是字符串类型)
字段和value hk {'age':18,'gemder':'male'}
优点:
1,特定条件下节约内存空间 满足两个条件才能节约 [1,字段小于512个,2:value不能超64个字节]--zipmap
2,可按需获取字段的值
hk 200 field 可精确查找具体的字段,如 age
传统方案:
python 准备一个200字段的字典 用 redis string :json.dumps(字典) r.set('pyd',d)
缺点:
1,不能让hash每一个field设置过期, hk:{'age':18},只能对hk设置
2,存储消耗大于字符串结构
Redus--hash原理
hash是无序的
redis是二维的,当你存一个key的时候,是一个一维数组(0,1,2,3,4)
数组 =( 0,1,2,3,4)
数组 = (guwenyuan,1,2,3,4)
1)hest h1 username guwenyuan 插入姓名
1,hash(username)% 5 = 0(比如等于0) 就到数组中的 0位置、
数组 = (guwenyuan,1,2,3,4)
2, hash(username)%5 =0(比如这个也等于0)
age = 18 姓名和年龄的位置为一致的就是hash碰撞
哈希碰撞:两个字段的哈希值对应的存储空间索引位置冲突,即为哈希碰撞
哈希碰撞解决方案:在当前位置下方开辟存储空间,进行存储 --单链法
3,扩容 - 当一维存储位置不够时,要进行扩容
redis出发扩容条件 当总字段个数等于一维数组的长度是,开始扩容
4,redis-渐进式的扩容 - 一次只迁一丢丢 保留两份数据,新旧两份数据,
哈希的应用场景
redis day02 下的更多相关文章
- redis windows下的环境搭建
先说下安装吧!感觉这东西跟mongodb差不多,安装和布置挺简单,下载地址:https://github.com/dmajkic/redis/downloads 下载下来的包里有两个,一个是32位的, ...
- 转:redis windows下的环境搭建
原文来自于:http://www.2cto.com/os/201204/125971.html 下载地址:https://github.com/dmajkic/redis/downloads 下载 ...
- Redis Windows下安装方法
一.安装 首先在网上下载Redis,下载地址:https://github.com/MicrosoftArchive/redis/releases 根据电脑系统的实际情况选择32位还是64位,在这里我 ...
- 信步漫谈之Redis—Linux下环境搭建
一.环境 Linux 系统:Suse11(SLES-11-SP3-DVD-x86_64-GM-DVD1)Redis 安装包:redis-4.0.11.tar.gz 下载地址:http://d ...
- [redis] mac下redis安装、设置、启动停止
From: https://www.cnblogs.com/shoren/p/redis.html 下载安装 需要下载release版本,下载地址: http://download.redis.io/ ...
- 【原】Redis windows下的环境搭建
下载地址:https://github.com/dmajkic/redis/downloads 下载下来的包里有两个,一个是32位的,一个是64位的.根据自己的实情情况选择,我的是64bit,把这个文 ...
- redis linux下的开机启动
redis linux下的环境搭建 http://www.cnblogs.com/zsg88/p/8321644.html 安装完redis-4.0.1后设置linux开机自启动. 1.在re ...
- Redis linux 下安装
Redis linux 下安装 下载Redis安装包,可以从Redis中文网站中下载 下载地址:http://www.redis.cn/download.html Redis4.0 稳定版本 使用&l ...
- Redis linux 下安装 及扩展配置
1.首先在/usr/local/ 创建文件夹 reids Cd /usr/local/ mkdir redis 2.把redis安装包放在redis目录下面进行解压phpredis-2.2.4.tar ...
随机推荐
- [题解] LuoguP4381 [IOI2008]Island
LuoguP4381 [IOI2008]Island Description 一句话题意:给一个基环树森林,求每棵基环树的直径长度的和(基环树的直径定义与树类似,即基环树上一条最长的简单路径),节点总 ...
- 算法设计和分析(Prim算法构建最小生成树)
问题: 给定无向图G(N,M)表明图G有N个顶点,M条边,通过Prim算法构造一个最小生成树 分析: 算法流程: 构造好的最小生成树就是step6 运行代码: #include<cstdio&g ...
- Spring Boot Actuator Endpoints
常用内建的Endpoints: beans:显示当前Spring应用上下文的Spring Bean完整列表(包含所有ApplicationContext的层次) conditions:显示当前应用所有 ...
- promise核心6 自定义promise
1.定义整体结构(不写实现) 定义一个自己的promise的库 lib(库的简写) 一个js文件.一个js模块(不能用es6 也不能commjs)(用es5模块语法 ) 匿名函数自调用.IIFE ( ...
- Codeforces 1296D - Fight with Monsters
题目大意: n 只怪兽,每只的血量为 h[i] ,你的攻击力为 a ,你的对手攻击力为 b 打每只怪兽时,都是你先出手,然后你的对手出手,这样轮流攻击 如果是你给予了怪兽最后一击,你就能得到一分 你还 ...
- 数组 bash shell
http://www.cnblogs.com/chengmo/archive/2010/09/30/1839632.html #!/bin/bash # 脚本检测到离线主机会发送邮件通知,可一直运行. ...
- OpenStack(四)——使用Kolla部署OpenStack多节点云
(1).实验环境 主机名 IP地址 角色 内存 网卡 CPU 磁盘 OpenStack-con 192.168.128.110 controller(控制) 8G 桥接网卡ens32和ens33 4核 ...
- SQL基础教程(第2版)第4章 数据更新:4-2 数据的删除(DELETE)
第4章 数据更新:4-2 数据的删除(DELETE) ● 如果想将整个表全部删除,可以使用DROP TABLE语句,如果只想删除表中全部数据,需使用DELETE语句.● 如果想删除部分数据行,只需在W ...
- c语言:自增自减运算符的操作详解
博主在回忆c语言的基本知识时,突然发现自增自减运算符(--.++)这个知识点有些模糊不清,故博主为了给同为小白的同学们提供一些经验,特写下这篇文章. 首先,自增自减运算符共有两种操作方式. 比如,我先 ...
- 用户交互Scanner
用户交互Scanner java.util.Scanner Scanner类可以获取用户的输入. Java 5 通过Scanner类的next()和nextLine()方法获取输入的字符串 在读取前我 ...