【redis】Redis的经典使用场景

news2024/10/5 21:17:37

目录

  • 1.最常见——缓存
  • 2.数据共享分布式
  • 3.分布式锁
  • 4.全局ID
  • 5.计数器
  • 6.限流
  • 7.位统计
  • 8.购物车
  • 9.用户消息时间线timeline
  • 10.消息队列
  • 11.抽奖
  • 点赞、签到、打卡
  • 13.商品标签
  • 14.商品筛选
  • 15.用户关注、推荐模型
  • 16排行榜

1.最常见——缓存

  • 数据类型:string
  • 例如:热点数据缓存(例如报表、商品库存、热门商品),对象缓存、全页缓存、可以提升热点数据的访问数据。

2.数据共享分布式

  • 数据类型:String 类型。
    • 因为 Redis 是分布式的独立服务,可以在多个应用之间共享
  • 例如:分布式Session
  • 依赖
    <dependency> 
     <groupId>org.springframework.session</groupId> 
     <artifactId>spring-session-data-redis</artifactId> 
    </dependency>
    

3.分布式锁

  • 数据类型:String 类型
    • setnx方法,只有不存在时才能添加成功,返回true
  • 例如
    public static boolean getLock(String key) {
        Long flag = jedis.setnx(key, "1");
        if (flag == 1) {
            jedis.expire(key, 10);
        }
        return flag == 1;
    }
    
    public static void releaseLock(String key) {
        jedis.del(key);
    }
    

4.全局ID

  • 数据类型:int类型,incrby,利用原子性
    • incrby userid 1000
  • 例如:分库分表的场景,一次性拿一段

5.计数器

  • 数据类型:int类型,incr方法
  • 例如:文章的阅读量、微博点赞数、允许一定的延迟,先写入Redis再定时同步到数据库

6.限流

  • 数据类型:int类型,incr方法
  • 例如:以访问者的ip和其他信息作为key,访问一次增加一次计数,超过次数则返回false

7.位统计

  • 数据类型:String类型的bitcount(1.6.6的bitmap数据结构介绍)
    • 字符是以8位二进制存储的
set k1 a
setbit k1 6 1
setbit k1 7 0
get k1 
/* 6 7 代表的a的二进制位的修改
a 对应的ASCII码是97,转换为二进制数据是01100001
b 对应的ASCII码是98,转换为二进制数据是01100010

因为bit非常节省空间(1 MB=8388608 bit),可以用来做大数据量的统计。
*/
  • 例如:在线用户统计,留存用户统计

    setbit onlineusers 01 
    setbit onlineusers 11 
    setbit onlineusers 20
    
  • 支持按位与、按位或等等操作

BITOPANDdestkeykey[key...] ,对一个或多个 key 求逻辑并,并将结果保存到 destkey 。       
BITOPORdestkeykey[key...] ,对一个或多个 key 求逻辑或,并将结果保存到 destkey 。 
BITOPXORdestkeykey[key...] ,对一个或多个 key 求逻辑异或,并将结果保存到 destkey 。 
BITOPNOTdestkeykey ,对给定 key 求逻辑非,并将结果保存到 destkey 。
  • 计算出7天都在线的用户
BITOP "AND" "7_days_both_online_users" "day_1_online_users" "day_2_online_users" ...  "day_7_online_users"

8.购物车

  • 数据类型:String 或hash。所有String可以做的hash都可以做
    在这里插入图片描述
    • key:用户id;field:商品id;value:商品数量。
    • +1:hincr。-1:hdecr。删除:hdel。全选:hgetall。商品数:hlen。

9.用户消息时间线timeline

  • 数据类型:list,双向链表,直接作为timeline就好了。插入有序

10.消息队列

  • List提供了两个阻塞的弹出操作:blpop/brpop,可以设置超时时间
  • blpop:blpop key1 timeout 移除并获取列表的第一个元素,如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。
  • brpop:brpop key1 timeout 移除并获取列表的最后一个元素,如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。
  • 上面的操作。其实就是java的阻塞队列。学习的东西越多。学习成本越低
  • 队列:先进先除:rpush blpop,左头右尾,右边进入队列,左边出队列
  • 栈:先进后出:rpush brpop

11.抽奖

  • 自带一个随机获得值
spop myset

点赞、签到、打卡

在这里插入图片描述

  • 假如上面的微博ID是t1001,用户ID是u3001
  • 用 like:t1001 来维护 t1001 这条微博的所有点赞用户
    • 点赞了这条微博:sadd like:t1001 u3001
    • 取消点赞:srem like:t1001 u3001
    • 是否点赞:sismember like:t1001 u3001
    • 点赞的所有用户:smembers like:t1001
    • 点赞数:scard like:t1001

13.商品标签

在这里插入图片描述

  • 用 tags:i5001 来维护商品所有的标签。
    • sadd tags:i5001 画面清晰细腻
    • sadd tags:i5001 真彩清晰显示屏
    • sadd tags:i5001 流程至极

14.商品筛选

// 获取差集
sdiff set1 set2
// 获取交集(intersection )
sinter set1 set2
// 获取并集
sunion set1 set2

在这里插入图片描述

  • 假如:iPhone11 上市了

    sadd brand:apple iPhone11
    
    sadd brand:ios iPhone11
    
    sad screensize:6.0-6.24 iPhone11
    
    sad screentype:lcd iPhone 11
    
  • 赛选商品,苹果的、ios的、屏幕在6.0-6.24之间的,屏幕材质是LCD屏幕

    sinter brand:apple brand:ios screensize:6.0-6.24 screentype:lcd
    

15.用户关注、推荐模型

  • follow 关注 fans 粉丝
  • 相互关注:
    • sadd 1:follow 2
    • sadd 2:fans 1
    • sadd 1:fans 2
    • sadd 2:follow 1
  • 我关注的人也关注了他(取交集):
    • sinter 1:follow 2:fans
  • 可能认识的人:
    • 用户1可能认识的人(差集):sdiff 2:follow 1:follow
    • 用户2可能认识的人:sdiff 1:follow 2:follow

16排行榜

  • id 为6001 的新闻点击数加1:

    zincrby hotNews:20190926 1 n6001
    
  • 获取今天点击最多的15条:

    zrevrange hotNews:20190926 0 15 withscores
    

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1829630.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

tauri嵌入外部二进制文件,以及sidecar是什么意思?

sidecar是什么意思 有时&#xff0c;为了使应用程序正常运行或防止用户安装额外的依赖项&#xff08;例如Node.js或Python或者ffmpeg等&#xff09;&#xff0c;你可能需要嵌入依赖的二进制文件&#xff0c;我们将这种二进制文件称为"sidecar"&#xff0c;中文意思就…

LabVIEW常用的加密硬件

LabVIEW在工程和科学领域中广泛应用&#xff0c;其中数据保护和程序安全尤为重要。为了确保数据的安全性和完整性&#xff0c;常用的加密硬件设备包括TPM&#xff08;可信平台模块&#xff09;、HSM&#xff08;硬件安全模块&#xff09;和专用加密芯片。本文将推荐几款常用的加…

[DDR4] DDR 简史

依公知及经验整理&#xff0c;原创保护&#xff0c;禁止转载。 专栏 《深入理解DDR4》 存和硬盘&#xff0c;这对电脑的左膀右臂&#xff0c;共同扛起了存储的重任。内存以其超凡的存取速度闻名&#xff0c;但一旦断电&#xff0c;内存中的数据也会消失。它就像我们的工作桌面&…

Python基础用法 之 变量

1.变量的定义 变量的作用&#xff1a;是⽤来保存数据的。定义的语法&#xff1a;变量名 数据值使用&#xff1a;直接使⽤变量名 即可使⽤变量中存储的数据。注意&#xff1a;变量必须先定义后使用。 (即 必须 先存⼊数据 才能 获取数据) 。 # 需求 1, 定义⼀个变量 保存你的名…

(超详细)基于动态顺序表实现简单的通讯录项目

前言&#xff1a; 我们在上一章节用c语言实现了线性表中的的动态顺序表&#xff0c;那么顺序表就只是顺序表吗&#xff1f;当然不是&#xff0c;使用顺序表结构可以实现很多项目&#xff0c;许多项目的数据结构都会用到顺序表&#xff0c;本章节我们就要使用顺序表实现一个简易…

爬虫案例:建设库JS逆向

爬虫流程 1. 确定目标网址和所需内容 https://www.jiansheku.com/search/enterprise/ 只是个学习案例&#xff0c;所以目标就有我自己来选择&#xff0c;企业名称&#xff0c;法定代表人&#xff0c;注册资本&#xff0c;成立日期 2. 对目标网站&#xff0c;进行分析 动态…

win10没有Hyper-v的解决方法

win10没有Hyper-v的解决方法 问题&#xff1a;最近想装下docker&#xff0c;但是在控制面板-程序-启用或关闭Windows功能下找不到Hyper-v节点。 废话不多说&#xff0c;直接上实操教程 1.将下面命令复制到文本文档中&#xff0c;并将文档重命名Hyper.cmd pushd "%~dp0&q…

29.添加录入注入信息界面

上一个内容&#xff1a;28.启动与暂停程序 以 28.启动与暂停程序 它的代码为基础进行修改 效果图&#xff1a; 新建Dialog 给新建的dialog添加空间&#xff0c;如下图 给每个输入框创建一个变量 代码&#xff1a; void CWndAddGame::OnBnClickedButton1() {static TCHAR BASE…

Go如何在本地引用以及发布并引用自定义工具包

如何引用本地自定义工具包 我们首先要准备两个项目&#xff0c;分别为需要引入的工具包和当前项目。 myutils、myproject1. myutils为我们的项目1-工具包 package mypakgeimport "strings"func IsContains(s string) bool {if strings.Contains(s, "a")…

HAL库开发--定时器的配置方式和占空比输出

知不足而奋进 望远山而前行 目录 文章目录 前言 目标 内容 需求 Timer配置 分频系数 Timer编码 总结 前言 定时器&#xff08;Timer&#xff09;在嵌入式系统中是一种重要的硬件资源&#xff0c;常用于生成精确的时间延迟、周期性触发事件或产生PWM信号等应用。本文将…

排序算法!

文章目录 插入排序冒泡排序选择排序归并排序希尔排序 提示&#xff1a;本文分析算法复杂度时&#xff0c;默认目标是n个元素升序排序&#xff0c;代码注释已经写好&#xff0c;就不单独拎出来了 插入排序 插入排序就是把待排序序列的第一个元素看作是有序序列&#xff0c;把第…

Internet Download Manager(IDM6.41)软件安装包下载及安装教程

Internet Download Manager有一个智能下载逻辑加速器&#xff0c;具有智能动态文件分割和安全的多部分下载技术&#xff0c;可以加速下载。与其他下载加速器和管理器不同&#xff0c;Internet下载管理器在下载开始之前对文件进行分段&#xff0c;而Internet下载管理器在下载过程…

华为云下Ubuntu20.04中Docker的部署

我想用Docker拉取splash&#xff0c;Docker目前已经无法使用&#xff08;镜像都在国外&#xff09;。这导致了 docker pull 命令的失败&#xff0c;原因是timeout。所以我们有必要将docker的源设置在国内&#xff0c;直接用国内的镜像。 1.在华为云下的Ubuntu20.04因为源的原因…

AMD Lisa Su专访:谈与英伟达、Intel竞争 直言Arm不是敌人

AMD CEO Lisa Su&#xff08;苏姿丰&#xff09;绝对称得上是芯片届的风云人物&#xff0c;尤其是进入了AI新时代&#xff0c;她的声望达到了十年来最高点。翻看其成长历史&#xff0c;苏姿丰在麻省理工学院获得电气工程博士学位后&#xff08;在麻省理工学院学习八年半&#x…

【Ardiuno】实验使用OPT语音模块播放语音(图文)

当我们需要在程序中播放语音内容时&#xff0c;就需要使用到语音模块&#xff0c;今天我们就来实验一下使用OPT语音模块来方法语音。 const int voicePin 5; const int voiceBusyPin 18; const int testLEDPin 2;unsigned long pmillis 0;int busyVal 0; …

C#联合Halcon机器视觉框架源码—升级版

相较于之前的NxtVision&#xff0c;本软件代码架构更加合理&#xff0c;且新增ui设计器、原来的vb脚本改为C#脚本&#xff0c;并尝试将视觉与运动控制相结合&#xff0c;是一体化的框架。 对源码有需求的&#xff0c;订阅本专栏后&#xff0c;私信我领取。

安卓网络通信(多线程、HTTP访问、图片加载、即时通信)

本章介绍App开发常用的以下网络通信技术&#xff0c;主要包括&#xff1a;如何以官方推荐的方式使用多线程技术&#xff0c;如何通过okhttp实现常见的HTTP接口访问操作&#xff0c;如何使用Dlide框架加载网络图片&#xff0c;如何分别运用SocketIO和WebSocket实现及时通信功能等…

记录一次centos扩容

背景 在Vscode上连虚拟机写项目&#xff0c;突然提示磁盘空间不足(no space left on device)&#xff0c;一开始打算删些东西&#xff0c;这里参考博客&#xff0c;写得挺清楚的&#xff0c;但是操作后我发现实在没啥文件可以删除&#xff0c;所以干脆不删了&#xff0c;直接扩…

Centos实现Mysql8.4安装及主主同步

8.4的Msyql在同步的时候与之前的版本有很大不同&#xff0c;这里记录一下安装流程 Mysql安装 官网下载 选择自己的版本&#xff0c;选第一个 复制下载链接 在服务器上创建一个msyql目录 使用命令下载,链接换自己的 wget https://dev.mysql.com/get/mysql84-community-relea…

【分布式计算】java消息队列机制

消息队列是一种在不同组件或应用之间进行数据传递的技术&#xff0c;通常用于处理异步通信。它允许消息的发送者&#xff08;生产者&#xff09;和接收者&#xff08;消费者&#xff09;之间进行解耦。 概念 消息队列是一种先进先出&#xff08;FIFO&#xff09;的数据结构&…