背景

  • Redis 是一个开源的内存数据结构存储系统。
  • 可以作为数据库、缓存和消息中间件使用。
  • 支持多种类型的数据结构。
  • Redis 内置了 复制(replication),LUA脚本(Lua scripting), LRU驱动事件(LRU eviction),事务(transactions) 和不同级别的 磁盘持久化(persistence)。
  • 通过 Redis 哨兵(Sentinel)和 Redis 集群(Cluster)的自动分区,提供高可用性(high availability)。

基本数据类型

  • 字符串(strings)

1、string 的过期时间在重新设置值之后会被清除

127.0.0.1:6379> set hello 3
OK
127.0.0.1:6379> get hello
"3"
127.0.0.1:6379> ttl hello
(integer) -1
127.0.0.1:6379> expire hello 3000
(integer) 1
127.0.0.1:6379> set hello 4
OK
127.0.0.1:6379> ttl hello
(integer) -1

2、设置 string 类型的值可以覆盖任何其他类型

127.0.0.1:6379> sadd settest 1,2
(integer) 1
127.0.0.1:6379> type settest
set
127.0.0.1:6379> set settest hello
OK
127.0.0.1:6379> type settest
string
127.0.0.1:6379> sadd settest a,b
(error) WRONGTYPE Operation against a key holding the wrong kind of value
  • 散列(hashes)
  • 列表(lists)

Redis lists 基于 Linked Lists 实现。头尾操作极速,检索较慢

  • 集合(sets)
  • 支持范围查找的有序集合(sorted sets)

有序集合的排序默认按照字典序排列

  • bitmaps
  • hyperloglogs
  • 支持按半径索引查询的地理空间(geospatial)

应用场景

string

  • 缓存数据

不管是简单和复杂的数据都可以直接转为string存储。

key: active:spring2019:title value:"2019春节活动" 操作:set

商品信息,省市区信息,活动配置等一系列不常变化的冷数据缓存

非常热门数据的缓存,游戏排行,后台每秒更新一次数据

  • 简单计数

2019春节活动参加人数

key: active:spring2019:total value:3045 操作:incr

  • 定时过期

一个人一天只能进行一次签到

key:active:checkin:userId:10000:day:20190101 value:签到时间戳 操作:expire

  • 分布式锁

下面的代码不严谨,nx 可以放并发

127.0.0.1:6379> set lockkey 1  nx
OK
127.0.0.1:6379> set lockkey 1  nx
(nil)

list

  • 用户排队

push,pop

  • 有序消息

push,pop

  • 实现生产者和消费者模型

阻塞式访问 BRPOP 和 BLPOP 命令

set

  • 去重列表

2019春节活动参加人数

key: active:spring2019:users value:100010,10020 操作:很多

  • 标签

用户标签

商家标签

春节活动一共有 abcde 5个任务,用户A已经完成a,b,用户B已经完成 c,d

  • 交集

用户A,用户B 都完成的任务

  • 并集

用户A,用户B 任一完成的任务

  • 差集

用户A还没有完成的任务

  • 获取随机元素

从礼品库 set 中随机获得一个礼品

hash

  • 同一资源的不同属性

用户在活动期间一共获得了不同种类奖品数量

key:active:spring:g'ifts:user:10010 value:{"giftA":2,"giftB":5} 操作:很多

可以直接对 giftA 执行 incr 操作

zset

  • 排行榜

用户消费排行,点赞排行等

key:active:spring:star:rank value:用户ID,score:点赞数量 操作:很多

根据分数获取 top 10

查询某个用户的分数

查询 得分在90-100 之间的用户

有时候我们的得分并不是由某一项业务值决定的,可能是由两项业务值来排序的,比如先看用户的实际得分,在看用户等级,那么我们在设计score的时候可以用小数点之前的值表示得分,小数点之后的值表示等级,如果有其他特殊要求,还可以考虑得分加上某个极大值来处理。

注意事项

  • 每个 key 都应该有合理的失效时间
  • string的过期时间在重新设值后会被覆盖
  • string类型的 set 操作可以覆盖类型
  • 合理使用相应的数据结构

不要用list存大量数据并检索

  • 合理规划 key 的数量

判断用户有没有参加应该用set,不应该每个用户一个key

  • 环境数据隔离
  • 业务数据隔离 用户 redis 业务 redis 活动 redis 应该做区分,活动的 redis 在活动结束后可以自由清理
  • 合理使用管道,lua 脚本和 redis 事务,提高性能,尤其是在脚本中使用 redis 的时候
  • 在有大量 key 的 Reids 线上系统,要在主库禁用 keys * 操作,防止卡死

转载于:https://my.oschina.net/u/920698/blog/3031587

Redis 在项目中合理使用经验总结相关推荐

  1. Redis在项目中合理使用经验总结

    背景 Redis 是一个开源的内存数据结构存储系统. 可以作为数据库.缓存和消息中间件使用. 支持多种类型的数据结构. Redis 内置了 复制(replication),LUA脚本(Lua scri ...

  2. (五)Redis在项目中应用

    目录 1. redis实现分布式锁 2. 订单或任务缓存 3. Redis和DB数据一致性 4. 大并发Redis穿透直接访问DB 5. 接口限流器 参考: Redis在项目中的运用总结 1. red ...

  3. Redis在项目中的地位及使用场景剖析

    Redis在项目中的地位及使用场景剖析 一. redis 特点 所有数据存储在内存中,高速读写 提供丰富多样的数据类型:string. hash. set. sorted set.bitmap.hyp ...

  4. Redis在项目中的使用及性能测试(续)

    [前言] 在上篇博文<SCPPO:Redis在项目中的使用及性能测试>中小编为大家分享了在程序中引入Redis以及性能的提升,不过遗留了功能的完善以及性能在服务器上的测试,咱们就一鼓作气, ...

  5. Redis在项目中的使用及性能测试

    强烈推荐一个大神的人工智能的教程:http://www.captainbed.net/zhanghan [前言] 在上篇博文中为大家分享了<SCPPO:C#中Redis封装的类>,有了这个 ...

  6. 8.redis解决分布式session问题 、redis在项目中难点

    a.什么是session session是一种会话技术,我们知道http是无状态协议的,就是这次连接传输数据后,下次连接服务器是不知道这次的请求是谁的,因此我们要做一个标记,让服务器知道每次请求是哪个 ...

  7. zset中的score_Redis 在项目中合理使用经验总结

    背景 Redis 是一个开源的内存数据结构存储系统. 可以作为数据库.缓存和消息中间件使用. 支持多种类型的数据结构. Redis 内置了 复制(replication),LUA脚本(Lua scri ...

  8. 【精品】Redis在项目中的应用场景

    Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合). String 缓存 简单key-value存储 热 ...

  9. Redis在项目中的应用(点评)

     一.缓存更新策略 主动更新策略 先删除缓存时,由于更新数据库耗时较多,在此期间如有另一线程查询缓存/数据库并写入缓存,则当前线程更新数据库后会导致缓存和数据库数据不一致,而反之出现不一致的概率要小得 ...

最新文章

  1. 创建型模式之Builder模式
  2. 字符串,那些你不知道的事
  3. 【leetcode】56. Merge Intervals 相邻线段归并
  4. Android应用开发相关下载资源
  5. mysql 查询语句_MySQL相关(一)- 一条查询语句是如何执行的
  6. 从零开始,做一个NodeJS博客(四):服务器渲染页面与Pjax
  7. 自信不疑的人不会做的15件事
  8. 学java要算法吗_学习java不可不知的几种算法
  9. 容器编排技术 -- Kubernetes 垃圾收集
  10. 冬季防御抗疫情宣传插画素材,时刻提醒大家注意
  11. JS之Window对象
  12. mysql和oracle用户管理_五种Oracle用户的授权与管理
  13. 有效提升 Virtual Server 2005 R2 with SP1 的速度
  14. CentOS操作系统keepalived安装步骤
  15. 为何阿里开发手册中,线程池不允许使用Executors去创建,而是通过ThreadPoolExecutor的方式
  16. 阿里巴巴分布式调度引擎tbschedule实战三tbschedule的调度原理
  17. vscode使用Setting Sync
  18. RGMII2GMII 分析
  19. 局域网即时通讯软件_做企业即时通讯软件,我们是认真的
  20. 【Android 逆向】ART 脱壳 ( dex2oat 脱壳 | /art/dex2oat/dex2oat.cc#Dex2oat 函数源码 )

热门文章

  1. 智能家居硬件小制作(含源码)《手势识别控制器》基于PAJ7620手势模块、L298N驱动板、arduino
  2. 说开源 讲红帽:从20亿美金到2017中国战略
  3. 死锁oracle rac,利用LOGMINER进行RAC环境下的死锁分析——转载
  4. 标题标题标题标题标题
  5. 31_Soft_Start_Up
  6. UE4 3dsmax 一个电脑屏幕模型的demo
  7. 数据新闻:大数据催生的新闻传播方式
  8. QQ阅读器技术框架解析之一《代码预览和分析》
  9. 常用套接字选项(SOL_SOCKET级别)
  10. HTML5期末大作业:旅游景点介绍网站设计——平遥古城(6页)HTML+CSS+JavaScript 学生DW网页设计作业成品 web课程设计网页规划与设计...