Redis 从入门到实战(二)


Redis数据类型

Redis有哪些数据类型?

一、String基本操作

1、业务数据的特殊性

1.1、作为缓存使用

- 原始业务功能设计
	- 秒杀
	- 618活动
	- 双11活动
	- 12306排队买票
- 运营平台监控到突发高频访问数据
	- 突发时政要闻,被强势关注围观
- 高频、复杂的统计数据
	- 在线人数

1.2、 附加功能

- 系统功能优化或升级
	- 单服务器升级集群
	- Session 管理
	- Token 管理

2、Redis 数据类型(5种常用)

- string
- hash
- list
- set
- sorted_set

3、Redis 数据存储格式

- redis 自身是一个Map,其中所有的数据都是采用key:value的形式存储
- 数据类型指的是存储的数据的类型,也就是value部分的类型,key部分永远都是字符串
  • string 类型
    • 简介
      • 存储的数据:单个数据,最简单的数据结构存储类型,也就是最常用的数据存储类型
      • 存储数据的格式:一个存储空间保存一个数据
      • 存储内容:通常使用字符串,如果字符串以整数的形式展示,可以作为数字操作使用(仍然是字符串)
    • string 类型数据的基本操作
      • 添加/修改数据
        eg:set key value
      • 获取数据
        eg:get key
      • 删除数据
        eg:del key
      • 添加/修改多个数据
        eg:mset key1 value1 key2 value2 …
      • 获取多个数据
        eg: mget key1 key2 …
      • 获取数据字符串个数(字符串长度)
        eg:strlen key
      • 追加信息到原始信息的后部(如果原始信息存在九追加,否则新建)
        eg:append key value在这里插入图片描述

数据类型-单指令操作与多指令操作

单数据操作与多操作的选择
  • set key value VS mset key1 value1 key2 value2 …
    • 单指令3条指令的执行过程:发送3条指令 + redis 执行3条指令 + redis返回3条指令
    • 多指令3条指令的执行过程:发送1条指令 + redis 执行3次指令 + redis返回1条指令

*在数据量较大的时候建议用 mset 具体根据实际情况,选择效率最高的命令。

二、string类型的扩展操作

业务场景(一)

大型企业级应用中,分表操作时基本操作,使用多张表存储同类型数据,但是对应的主键id必须保证统一性,不能重复。Oracle数据库具有sequence设定,可以解决该问题,但是MySQL数据库并不具有类似的机制,那么应该如何解决?

解决方案

  • 设置数值数据增加指定范围的值
    • incr key
    • incrby key increment
    • incrbyfloat key increment
  • 设置数值数据减少指定范围的值
    • decr key
    • decrby key increment

在这里插入图片描述注意:是没有 decrbyfloat 的命令的,但是incrby 、incrbyfloat、decrby 可以做负运算

在这里插入图片描述

string 作为数值操作

  • string在redis内部存储默认就是一个字符串,当遇到增减类操作incr,decr时会转成数值型计算。
  • redis所有的操作都是原子性的,采用单线程处理所有业务,命令是一个一个执行的,因此无需考虑并发带来的数据影响
  • 注意: 按数值进行操作的数据,如果原始数据不能转成数值,或超越了redis数值上限范围,将报错。 922337203685475807(java中long型数据最大值,Long.MAX_VALUE)

业务场景(二)

某大型女团出道海选投票,只能通过微信投票入口进行投票,每个微信号每小时只能投1票。
电商商家开启热门商品推荐,热门商品维持时间为3天,3天后自动取消商品的热门推荐。
新闻网站出现热点新闻,热搜最大的特征就是时效性,如何自动控制热搜新闻的时效性?

解决方案

  • 设置数据具有指定的生命周期
    • setex key seconds value 秒
    • psetex key milliseconds value 毫米
      在这里插入图片描述
      注意:当设置一个指定周期的数据时,eg: setex k 10 1,再 set k 3,那么之前的setex就会被清除,超过时间后依然还在,get k会显示3
      在这里插入图片描述- Tip:redis控制数据的生命周期,通过数据是否失效控制业务行为,适用于所有具有时效性限定控制的操作。

三 、string类型数据操作的注意事项

数据操作不成功的反馈与数据正常操作之间的差异

- 表示试运行结果是否成功
	- (integer)0   ——>false	失败
	- (integer)1   ——>true	成功
- 表示运行结果值
	- (integer)3   ——>3	3个
	- (integer)1   ——>1	1个
- 数据未获取到
	- (nil)等同于null
- 数据最大存储量
	- 512MB		(了解即可)
- 数值计算最大范围(java中的long的最大值)
	922337203685775807(正负)

四、string类型的应用场景

业务场景

  • 主页高频访问信息显示控制,例如新浪微博大V主页显示粉丝数和微博数量

解决方案

  • 在redis中为大V用户设定用户信息,以用户主键和属性值作为Key,后台设定定时刷新策略即可
  • 在redis中,给出一个标准的规范方式:表名:主键名:主键值:属性名 作为Key
    • eg: user🆔35067:fans ——> 12210947
    • eg: user🆔35067:blogs ——> 6146
    • eg: user🆔35067:focuss ——> 121
  • 在redis中以json格式存储大V用户信息,定时刷新(也可以使用hash类型)
    • eg: user🆔3506728370 ——> {id:3506728370,name:小明,fans:12210947,blogs:6146,focus:121}

两种选择都可以,根据场景不同选择不同的存储方式,第一种操作和改变数据比较方便,第二种修改,需要全部修改

在这里插入图片描述

Key的设置约定

  • 数据库中的热点数据key命名惯例

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值