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

背景

  • 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 * 操作,防止卡死

Redis 在项目中合理使用经验总结的更多相关文章

  1. redis在项目中的应用

    redis在项目中的应用  ps:PHP 会自动 关redis连接 不需要手动关 对于临时的数据 可以不经过数据库直接redis上操作<pre>/*消息队列实例 消息队列详细步骤在http ...

  2. spring3.0结合Redis在项目中的运用

    推荐一个程序员的论坛网站:http://ourcoders.com/home/ 以下内容使用到的技术有:Redis缓存.SpringMVC.Maven.项目中使用了redis缓存,目的是在业务场景中, ...

  3. redis在项目中的使用(单机版、集群版)

    1.下载jar包:jedis-2.6.2.jar 2.代码: JedisDao.java: package com.test.www.dao; public interface JedisDao { ...

  4. Spring + SpringMVC + Mybatis项目中redis的配置及使用

    maven文件 <!-- redis --> <dependency> <groupId>redis.clients</groupId> <art ...

  5. go语言实战教程:Redis实战项目应用

    项目Redis配置 在实战项目中使用Redis功能,首先需要进行Redis配置.本实战项目中,关与Redis的配置项包含:连接类型.地址.端口.公共前缀.以上配置项被定义包含在Iris框架的redis ...

  6. 项目中使用Prism框架

    Prism框架在项目中使用   回顾 上一篇,我们介绍了关于控件模板的用法,本节我们将继续说明WPF更加实用的内容,在大型的项目中如何使用Prism框架,并给予Prism框架来构建基础的应用框架,并且 ...

  7. Redis 在NETCore中的应用

    Redis 在NETCore中的应用 Redis 在netFramework中的应用  也一样 新建.NETCORE(webapi)项目 安装NuGet //查询NuGet语句 Find-Packag ...

  8. 【新手总结】在.Net项目中使用Redis作为缓存服务

    最近由于项目需要,在系统缓存服务部分上了redis,终于有机会在实际开发中玩一下,之前都是自己随便看看写写,很零碎也没沉淀下来什么,这次算是一个系统学习和实践过程的总结. 和Redis有关的基础知识 ...

  9. redis在java项目中的使用

    在上一篇文章中已经讲了redis的spring配置,这篇将会描述redis在java项目中的使用. redis存储形式都是key-value(键值对),按照存储的内容分为两种,一种是存简单数据,即数字 ...

随机推荐

  1. HTML表单__表单元素属性

    看完"HTML表单__表单元素"那一节的同学会发现,同是input标签,type属性值不一样的时候,input类型完全不一样.type就是input的一个属性,除type之外,还有 ...

  2. JAVA基础之JDK、JRE、JVM关系

    什么是JRE和JDK JDK(Java Development Kit Java开发工具包) JDK是提供给Java开发人员使用的,其中包含了java的开发工具,也包括了JRE.所以安装了JDK,就不 ...

  3. springMVC-11-验证码

    springMVC-11-验证码 导入依赖 <!--Kaptcha 验证码依赖 前面已导过servlet-api需排除--> <dependency> <groupId& ...

  4. springMVC-10-文件上传

    导入依赖(注意会和servlet-api依赖冲突) <!--文件上传jar包, 前面已导过servlet-api需排除--> <dependency> <groupId& ...

  5. AntDesignBlazor 学习笔记

    AntDesignBlazor是基于 Ant Design 的 Blazor 实现,开发和服务于企业级后台产品.我的 Blazor Server 学习就从这里开始,有问题可以随时上 Blazor 中文 ...

  6. 【动态规划DP】[USACO16OPEN]248

    题目描述 Bessie likes downloading games to play on her cell phone, even though she doesfind the small to ...

  7. 选择排序(selection_sort)——Python实现

      # 选择排序 # 作用:对给出的n个顺序不定的数进行排序 # 输入:任意数组A # 输出:按顺序排列的数组A # 时间复杂度 (n(n-1))/2 # 选择排序 # 第一趟:选择第一个元素,依次与 ...

  8. 项目去O实践

    现状(自下而上) 1.Oracle数据库,表,序列,存储过程,视图 2.ibatis框架,映射xml中的sql语句 3.应用中通过指定字符串的形式获取查询结果   目标 1.置换数据库为PG数据库,迁 ...

  9. 剑指 Offer 40. 最小的k个数

    剑指 Offer 40. 最小的k个数 输入整数数组 arr ,找出其中最小的 k 个数.例如,输入4.5.1.6.2.7.3.8这8个数字,则最小的4个数字是1.2.3.4. 示例 1: 输入:ar ...

  10. jdk的下载与安装教程

    最近在学逆向,就是要反编译人家的java代码,在这之前要先安装环境,下面是下载和安装JDK的教程: 1.JDK下载地址: http://www.oracle.com/technetwork/java/ ...