redis 02

本文涉及的产品
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
简介: redis 02

学习资料

https://www.bilibili.com/video/BV1CJ411m7Gc?p=6

数据存储类型介绍

业务数据的特殊性

作为缓存使用

  1. 原始业务功能设计
    秒杀
    618活动
    双十一活动
    排队购票
  2. 运营平台监控到的突发高频访问数据
    突发市政要闻,被强势关注围观
  3. 高频、复杂的统计数据
    在线人数
    投票排行榜

附加功能

系统功能优化或升级

  • 单服务器升级集群
  • Session管理
  • Token管理

Redis 数据类型(5种常用)

  • string --> String
  • hash --> Hashmap
  • list --> LinkList
  • set --> HashSet
  • sorted_set --> TreeSet

String

redis 数据存储格式

  • redis自身是一个Map,其中所有的数据都是采用key:value的形式存储
  • 数据类型指的是存储的数据的类型,也就是value部分的类型,key部分永远都是字符串
    e84c35d3b7a0b79bd67ac23ce433ebb2_watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FtcW0zMw==,size_16,color_FFFFFF,t_70.png
    String 类型
  • 存储的数据:单个数据,最贱的数据存储类型,也是最常用的数据存储类型
  • 存储数据的格式:一个存储空间保存一个数据
  • 存储内容:通常使用字符串,如果字符串以整数的形式展示,可以作为数字操作使用
  • 589ac5cc925892e30da8763f6f1bcdef_20200409191821527.png

String 类型数据的基本操作

  • 添加/修改数据

set key value

  • 获取数据

get key

  • 删除数据

del key

  • 添加/修改多个数据

mset key1 valueq key2 value2 …

  • 获取多个数据

mget key1 key2 …

  • 获取数据字符个数(字符串长度)

strlen key

  • 追加信息到原始信息后部(如果原始信息存在就追加,否则新建)

append key value

String类型数据的扩展操作

业务场景

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

解决方案

  • 设置数值数据增加指定范围的值

incr key

incrby key increment

incrbyfloat key increment

  • 设置数值数据减少指定范围的值

decr key

decrby key increment

28d6ab1dfb14496224a2106c34fc3fd4_20200409194208601.png

d00fd56c2c6c396d0a998e7f12bf6aac_2020040919422955.png

String作为数值操作

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

String 数据时效性设置

业务场景

场景一:“最强女生”,启动海选投票,只能通过微信投票,每个微信号每4个小时只能投1票。

场景二:电商商家开启热门商品推荐,热门商品不能一直处于热门期,每种商品热门期维持3天,3天后自动取消热门

场景三:新闻网站会出现热点新闻,热点新闻最大的特征是对时效性,如何自动控制热点新闻的时效性

解决方案

  • 设置数据具有指定的声明周期

setex key seconds value

psetex key milliseconds value

Tips 2:

  • redis 控制数据的生命周期,通过数据是否失效控制业务行为,适用于所有具有时效性限定控制的操作

String 类型的注意事项

  • 数据操作不成功的反馈与数据正常操作之间的差异
    1、表示运行结果是否成功
     (integer)0–>false 失败
     (integer)1–>true 成功
    2、表示运行结果值
     (integer)3–>3 3个
     (integer)1–>1 1个
  • 数据未获取到
    (nil)等同于null
  • 数据最大存储量
    512MB
  • 数值计算最大范围(java中的long的最大值)

String类型应用场景

业务场景

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

bcace3b7c4e3e0784ffcede2e2c165a6_watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FtcW0zMw==,size_16,color_FFFFFF,t_70.png

key的设置约定

  • 数据库中的热点数据key命名惯例
  • 43dd5ca49560a5d655a830d6b38c0cd7_20200413220259916.png


相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
3天前
|
存储 NoSQL 测试技术
【Redis】redis为什么快
【Redis】redis为什么快
|
4月前
|
NoSQL 网络协议 安全
Redis系列-1.Redis浅谈
Redis系列-1.Redis浅谈
20 0
|
8月前
|
NoSQL 安全 Redis
|
9月前
|
运维 NoSQL Shell
redis-2
redis-2
51 0
|
9月前
|
消息中间件 NoSQL 测试技术
Redis2
Redis2
92 0
|
9月前
|
存储 缓存 NoSQL
Redis5
Redis5
101 0
|
10月前
|
NoSQL Redis 数据库
什么是Redis
Redis,即远程字典服务,是一个开源的使用ANSI C语言编写,支持网络,可基于内存亦可持久化的日志型,Key-Value数据库。类似于map
44 0
|
11月前
|
存储 缓存 NoSQL
Redis为什么那么快
Redis为什么那么快
85 1
Redis为什么那么快
|
11月前
|
设计模式 移动开发 缓存
可算知道Redis为什么这么快了
可算知道Redis为什么这么快了
105 0
|
存储 消息中间件 缓存
Redis总结(二)
redis 和 memcached 什么区别?为什么高并发下有时单线程的 redis 比多线程的memcached 效率要高?区别:1.mc 可缓存图片和视频。rd 支持除 k/v 更多的数据结构;2.rd 可以使用虚拟内存,rd 可持久化和 aof 灾难恢复,rd 通过主从支持数据备份;3.rd 可以做消息队列。原因:mc 多线程模型引入了缓存一致性和锁,加锁带来了性能损耗。redis 主从复制如何实现的?redis 的集群模式如何实现?redis 的 key 是如何寻址的?
89 0