redis的string类型及bitmap介绍

目录
  • redis运行原理
  • redis使用
    • redis二进制安全
    • getset命令
  • 位图(bitmap)
  • 场景题
  • 总结

redis运行原理

redis有很多的客户端连接进来,站在redis所在机器的角度来说,就是有很多socket的连接,并且是打在内核
上面的,redis是一个进程,进程可以调用内核上的epoll,来遍历寻找哪一个客户端发送数据过来了(这里是单进程单线程来处理用户数据的)。

redis使用

redis默认有16个库

输入:
进入基本分组

keys * 查询所有的key
FLUSHDB 清除所有的key

对于如上nx的命令是我当前的key如果没有被设置则把ooxx给设置成功,如果设置的key已经有value了,
则返回nil (多用于分布式锁的获取,只能有一个获取成功)

对于xx命令,只有存在的时候才能进行操作。

mset命令(设置多个key和value)

append命令以及getrange命令

redis正反向索引

前面是从0,1,2开始的,后面则是从-1开始递减的,所以也可以按照下面方式写

SETRANGE 在给定范围设置字符串:

获取字符串长度:

获取key所对应的value类型(主要是看set命令分组是在string上面的)

再来看一下object命令

它可以查看value的编码类型(面向 redis string类型,除了字符串操作还有计算的操作【计算的操作面向数值的】)

incr和decr相关命令【可用于抢购,秒杀,点赞,评论数,详情页(比如说淘宝详情页,一定会后端发起一个异步查询购买数等,查redis,可以规避并发下,对数据库的事务操作,
完全由redis内存操作代替)】

redis二进制安全

redis进程与外界交互的时候,面向流我们有字节流,以及字符流,那么redis客户端
访问的时候,从socket里面拿到的是字节流的数据,只要未来的双方客户端和服务端有同样的
编解码方式,数据就不会被破坏。
如 set k1 = 9999,执行strlen 输出4,redis里面存这个数据是按照一个字符一个字节来存入的,直接
向字符流去写,执行incr之后是先把字节流拿出来转换成数值的,转换成数值之后会更新key的encoding
编码,只要加成功就更新成int了,如果下次加的话就可以直接检查这个encoding类型了,如果加的数
不是int类型则报错
另一种如 set k2 中,是占3个字节的(软件和redis通信用的utf-8)
我们再设置一个k3占2个字节(gbk编码)

然后退出用redis-cli --raw来登录,会触发一个格式化(如果不带上–raw是只会识别ascii码的,超出部分则按照16进制来展示的,如果加上raw则会触发编码集的格式化)

key上有encoding的话,就相当于做了一个优化,来判断我当前这个操作是否是可行的

getset命令

getset命令是将旧的值返回并将新的值给设置进去,(相对于get 和set单独执行的话,要发两个单独
的命令过去,IO通信两次,而这种方式只通信了一次【节省资源】)

mset 设置多个key多个value
msetnx (设置多个key对应的value保证原子性)下面的图中msetnx 在设置k3的时候失败了

位图(bitmap)

setbit 方法,在对应的bit位上面设置值

bitpos命令:
找到第一个字节 中第一个1出现的位置

找到第二个字节出现1的第一个位置

统计1在字节范围出现了几次:

bitop 命令可以按位对value进行与和或等运算

场景题

1、公司有用户系统,统计用户的登录天数,且窗口随机(某天往前推一周,以及往后推一周,用户登录的天数统计一下)
一年设置为400天,可以使用50个字节存用户全年的登录状态

-2 和-1为最后两个字节(查询300天到第400天)登录多少次。【让用户为key登录天数为value】
当然如果觉得用户量特别大的话可以考虑一部分用户存一个redis,另一部分
存另一个redis【注:1个用户50个字节,那么20个用户存1k的空间,20000个用户越需要1MB的空间
2000000个用户则需要100M的空间】

2、京东618做活动送礼物,大库备货多少个礼物?假设有2E用户
1、对用户做分类(分为僵尸用户 冷热用户/忠诚用户)
所以需要做活跃用户统计,
什么是活跃用户:
比如说 1号-3号 连续登录 对重复登录的去重
redis如何做
首先在2022年1月1日id为1的用户登录了 给bit位的1位上设置1
在2022年1月2日id为1和id为7的用户登录了分别在bit位1和bit位7上设置1

总结

key的type类型,是用于判断访问的方法是不是具备这个类型的操作,可以快速返回错误,可以规避
异常。
encoding是可以规避同一种type类型但是根据不同的表现形式做计算这件事,
还有length属性,如果数据未发生改变可以直接返回长度

到此这篇关于redis的string类型及bitmap介绍的文章就介绍到这了,更多相关redis的string类型 内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • PHP使用redis位图bitMap 实现签到功能

    一.需求 记录用户签到,查询用户签到 二.技术方案 1.使用mysql(max_time字段为连续签到天数) 思路: (1)用户签到,插入一条记录,根据create_time查询昨日是否签到,有签到则max_time在原基础+1,否则,max_time=0 (2)检测签到,根据user_id.create_time查询记录是否存在,不存在则表示未签到 2.使用redis位图功能 思路: (1)每个用户每个月单独一条redis记录,如00101010101010,从左往右代表01-31天(每月有几

  • Redis中3种特殊的数据类型(BitMap、Geo和HyperLogLog)

    前言 Reids 在 Web 应用的开发中使用非常广泛,几乎所有的后端技术都会有涉及到 Redis 的使用.Redis 种除了常见的字符串 String.字典 Hash.列表 List.集合 Set.有序集合 SortedSet 等等之外,还有一些不常用的数据类型,这里着重介绍三个.下面话不多说了,来一起看看详细的介绍吧. BitMap BitMap 就是通过一个 bit 位来表示某个元素对应的值或者状态, 其中的 key 就是对应元素本身,实际上底层也是通过对字符串的操作来实现.Redis 从

  • Redis数据类型string和Hash详解

    目录 String类型命令操作 设置指定key的值 获取指定key的值 返回key中字符串值的子串 获取多个给定key的值 返回key所对应的字符串的长度 设置一个或多个键值对 将key中所存储的数值加一 将key中所存储的数值减一 字符串追加 Hash类型 设置一个Hash数据 获取指定哈希表中所有的字段和值 获取存储在哈希表中指定字段的值 删除一个或多个哈希表字段 获取哈希表中字段的数量 获取哈希表中的所有字段 获取哈希表中所有的值 摘要:Redis中有五大数据类型,分别是String.Li

  • 浅谈RedisTemplate和StringRedisTemplate的区别

    目录 一.区别 二.问题总结 三.案例:springboot整合redis五种数据结构API 1.string(字符串)类型 2.hash(哈希)类型 3.list(列表)类型 4.set(无序集合)类型 5.zset(有序集合)类型 6.删除key 四.总结: 一.区别 区别点1:两者的关系是StringRedisTemplate继承RedisTemplate.RedisTemplate是一个泛型类,而StringRedisTemplate则不是. 区别点2:两者序列化策略不同, String

  • Python操作redis实例小结【String、Hash、List、Set等】

    本文实例总结了Python操作redis方法.分享给大家供大家参考,具体如下: 这里介绍详细使用 1.String 操作 redis中的String在在内存中按照一个name对应一个value来存储 set() #在Redis中设置值,默认不存在则创建,存在则修改 r.set('name', 'zhangsan') '''参数: set(name, value, ex=None, px=None, nx=False, xx=False) ex,过期时间(秒) px,过期时间(毫秒) nx,如果设

  • Redis教程(二):String数据类型

    一.概述: 字符串类型是Redis中最为基础的数据存储类型,它在Redis中是二进制安全的,这便意味着该类型可以接受任何格式的数据,如JPEG图像数据或Json对象描述信息等.在Redis中字符串类型的Value最多可以容纳的数据长度是512M. 二.相关命令列表: 命令原型 时间复杂度 命令描述 返回值 APPENDkeyvalue O(1) 如果该Key已经存在,APPEND命令将参数Value的数据追加到已存在Value的末尾.如果该Key不存在,APPEND命令将会创建一个新的Key/V

  • Redis中的bitmap详解

    1.什么是bitmap? bitmap也叫位图,也就是用一个bit位来表示一个东西的状态,我们都知道bit位是二进制,所以只有两种状态,0和1. 2.为什么要有bitmap? bitmap的出现就是为了大数据量而来的,但是前提是统计的这个大数据量每个的状态只能有两种,因为每一个bit位只能表示两种状态. 下面我们直接以一个统计亿级用户活动的状态来说明吧. 3.案例说明 3.1.案例描述 如果有一个上亿用户的系统,需要我们去统计每一天的用户登录情况,我们应该如何去解决? 前提条件:设置在9月19号

  • RedisTemplate常用操作方法总结(set、hash、list、string等)

    目录 String类型 Hash类型 List类型 Set类型 zSet类型 Redis常用的数据类型: String Hash List Set zSet Sorted set String类型 保存和读取String(最常用的) System.out.println("缓存正在设置........."); redisTemplate.opsForValue().set("key1","value1"); redisTemplate.opsFo

  • Redis中一个String类型引发的惨案

    ​ 曾经看到这么一个案例,有一个团队需要开发一个图片存储系统,要求这个系统能快速记录图片ID和图片存储对象ID,同时还需要能够根据图片的ID快速找到图片存储对象ID.我们假设用10位数来表示图片ID和图片存储对象ID,例如图片的ID为1101021043,它所对应的图片存储对象的ID为2301010051,可以看到图片ID和图片存储ID正好是一一对应的,是典型的key-value形式,所以首先会想到直接使用String类型来保存数据.把图片ID和图片存储ID分别作为键值对的key和value来保

  • redis的string类型及bitmap介绍

    目录 redis运行原理 redis使用 redis二进制安全 getset命令 位图(bitmap) 场景题 总结 redis运行原理 redis有很多的客户端连接进来,站在redis所在机器的角度来说,就是有很多socket的连接,并且是打在内核上面的,redis是一个进程,进程可以调用内核上的epoll,来遍历寻找哪一个客户端发送数据过来了(这里是单进程单线程来处理用户数据的). redis使用 redis默认有16个库 输入:进入基本分组 keys * 查询所有的keyFLUSHDB 清

  • Redis02 使用Redis数据库(String类型)全面解析

    一 String类型 首先使用启动服务器进程 : redis-server.exe 1. Set 设置Key对应的值为String 类型的value. 例子:向 Redis数据库中插入一条数据类型为String 的记录. 在客户端输入命令: C:\software\redis\64bit>redis-cli.exe -h 127.0.0.1 -p 6379 redis 127.0.0.1:6379> set foo test OK redis 127.0.0.1:6379> get fo

  • Redis中的String类型及使用Redis解决订单秒杀超卖问题

    本系列将和大家分享Redis分布式缓存,本章主要简单介绍下Redis中的String类型,以及如何使用Redis解决订单秒杀超卖问题. Redis中5种数据结构之String类型:key-value的缓存,支持过期,value不超过512M. Redis是单线程的,比如SetAll & AppendToValue & GetValues & GetAndSetValue & IncrementValue & IncrementValueBy等等,这些看上去像是组合命

  • Jedis对redis的五大类型操作代码详解

    本篇主要阐述Jedis对redis的五大类型的操作:字符串.列表.散列.集合.有序集合. JedisUtil 这里的测试用例采用junit4进行运行,准备代码如下: private static final String ipAddr = "10.10.195.112"; private static final int port = 6379; private static Jedis jedis= null; @BeforeClass public static void init

  • Redis高级数据类型Hyperloglog、Bitmap的使用

    前言 很多小伙伴在面试中都会被问道 Redis的常用数据结构有哪些? 可能很大一部分回答都是 string.hash.list.set.zset.当然啦,这个答案肯定是没有错的,但是相信这个答案,面试官已经听的耳朵都起茧了. 本身我们选择的这个行业竞争就极强,学历拼不过难道还要知识都拼不过吗??? 希望进来的小伙伴能好好看完这篇文章,也希望你以后的回答能是 常用的数据结构有string.hash.list.set.zset,但我平时可能还会用到 Hyperloglog和Bitmap.相信面试官听

  • Java中redis的基本类型

    redis存储数据的基本类型有:string(字符串类型).hash(散列类型).list(列表类型).set(集合类型).zset(有序集合类型). redis中的每个对象都由一个redisObject结构来表示: /*  * Redis 对象  */ typedef struct redisObject {     // 类型     unsigned type:4;             // 不使用(对齐位)     unsigned notused:2;     // 编码方式  

  • 一文搞懂Redis中String数据类型

    概述: 字符串类型是Redis中最为基础的数据存储类型,它在Redis中是二进制安全的,这便意味着该类型可以接受任何格式的数据,如JPEG图像数据或Json对象描述信息等.在Redis中字符串类型的Value最多可以容纳的数据长度是512M. 相关命令列表: 命令原型 时间复杂度 命令描述 返回值 APPEND O(1)  如果该Key已经存在,APPEND命令将参数Value的数据追加到已存在Value的末尾.如果该Key不存在,APPEND命令将会创建一个新的Key/Value. 追加后Va

  • Redis序列化转换类型报错的解决

    Cannot convert value of type 'org.springframework.data.redis.core.convert.MappingRedisConverter' to required type 'org.springframework.data.redis.core.mapping.RedisMappingContext': no matching editors or conversion strategy found 在setValue的序列化方式的时候报错

随机推荐