Redis的应用场景有哪些

0.什么是Redis?

基于内存的数据结构存储系统,它可以用作数据库、缓存和消息代理。Redis 支持多种数据结构,包括字符串(String)、哈希表(Hashes)、列表(Lists)、集合(Sets)、有序集合(Sorted Sets)以及更复杂的数据结构。

以下是关于 Redis 的一些主要特点:

  1. 性能高:Redis 能读的速度是 110000 次/s,写的速度是 81000 次/s。

  2. 丰富的数据类型:Redis 支持二进制案例的 Strings, Lists, Hashes, Sets 及 Ordered Sets 数据类型操作。

  3. 原子性:Redis 的所有操作都是原子性的,意味着要么成功执行要么失败完全不执行。

  4. 丰富的特性:Redis 还支持 publish/subscribe, 通知, key 过期等等特性

注意的是redis的事务只保证原子性,而不是用来处理可能的错误状态,也就是不能回滚。

1.缓存

由于 Redis 的高性能,它经常被用作缓存层,来快速读取频繁访问的数据,减轻后端数据库的压力。比如主页的数据,但是也可以用ES来代替

2.存储会话

比如我们做登录的时候的状态可以存储到redis中,还可以实现token的过期时间

3.zSet实现接口限流

滑动窗口思想

SpringAOP+自定义注解实现限制接口访问频率,利用滑动窗口思想Redis的ZSet(附带整个Demo)

4.布隆过滤器实现签到功能

在实现签到功能时,你可以将布隆过滤器用作一个预先检查的步骤。当一个用户尝试签到时,你可以首先检查他们是否已经在布隆过滤器中。如果不在,那么你可以安全地认为他们还没有签到,并允许他们进行签到操作。然后,你可以将他们的标识信息(如用户ID)加入到布隆过滤器中。如果他们在布隆过滤器中,那么可能他们已经签到过了,你可以进行进一步的检查(如在数据库中进行查找)以确认

5.共同好友的实现

Set数据结构可以使用交集和并集实现共同好友

6.Geo可以实现地理位置的功能

比如实现两个地理位置之间的距离,距离最近的顺序排行

7.分布式锁

setnx实现分布式锁

8.延迟队列

在 Redis 中,你可以通过使用 Sorted Set 数据结构来实现延迟队列。这种实现方式的关键在于 Sorted Set 中的每个元素都会关联一个分数,你可以把这个分数当作消息的延迟时间。

  • 使用 ZADD 命令将消息添加到 Sorted Set 中,消息的延迟时间(Unix 时间戳)作为分数:
  • # 添加一个延迟消息
    redis-cli ZADD myDelayQueue 1632292800 message1
  • 使用 ZRANGEBYSCORE 命令找出所有已经到期的消息:
  • # 获取所有已经到期的消息
    redis-cli ZRANGEBYSCORE myDelayQueue 0 $(date +%s)

    在这个例子中,$(date +%s) 是当前的 Unix 时间戳。

  • 使用 ZREMRANGEBYSCORE 命令移除所有已经到期的消息:
  • # 移除所有已经到期的消息
    redis-cli ZREMRANGEBYSCORE myDelayQueue 0 $(date +%s)

注意:你需要定期运行第 2 步和第 3 步,以便获取和处理到期的消息。另外,这只是一个基本的示例,实际的应用可能会更复杂,例如,你可能需要处理消息的确认、重试、超时等情况。

9.排行榜

使用zset实现排行榜功能,

key score member 

score是分数,可以用来排序

zadd 100 user  表示user的分数为100

  1. ZRANK key member:此命令返回有序集keymember的排名,其中有序集成员按分数值递增(从小到大)顺序排列。排名以0为底,也就是说,分数值最小的成员排名为0。

  2. ZREVRANK key member:此命令返回有序集keymember的排名,其中有序集成员按分数值递减(从大到小)顺序排列。

  3. ZRANGE key start stop [WITHSCORES]:返回有序集key中,指定区间内的成员。其中成员的位置按分数值递增(从小到大)来排序。具有相同分数值的成员按字典序来排列。可选的WITHSCORES参数让成员和它的分数值一并返回。

  4. ZREVRANGE key start stop [WITHSCORES]:返回有序集key中,指定区间内的成员。其中成员的位置按分数值递减(从大到小)来排列。可选的WITHSCORES参数让成员和它的分数值一并返回

ZADD myset 1 "one"
ZADD myset 2 "two"
ZADD myset 3 "three"ZRANK myset "one"   ##返回 0ZREVRANK myset "one"  ##返回 2ZRANGE myset 0 -1    ##返回 one two threeZREVRANGE myset 0 -1  ## 返回 three two one

以上只是列出部分,还有许多功能可以实现 

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

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

相关文章

C语言入门课程学习笔记-6

C语言入门课程学习笔记-6 第27课 - 字符数组与字符串(上)第28课 - 字符数组与字符串(下)第29课 - 数组专题练习(上)第30课 - 数组专题练习(下) 本文学习自狄泰软件学院 唐佐林老师的…

不只有 Spring,这四款Java 基础开发框架同样值得关注!

Java 开发不只有 Spring ,今天给大家推荐几个同样优秀的 Java 基础开发框架,为日常项目开发提供更多的选择。答应我,请不要再叫我 Spring 小子了,​好吗? 项目概览: Guice:轻量级依赖注入框架 …

2024Mac系统热门游戏排行榜 Mac支持的网络游戏有哪些?mac能玩哪些大型网游 苹果电脑Mac游戏资源推荐 Mac玩Windows游戏

“游戏是这个世界上唯一能和女性争夺男朋友的东西(/滑稽,有不少女生也喜欢玩游戏)。” 虽然只是一句玩笑话,不过也可以看出游戏对大多数男生来说是必不可少的一项娱乐活动了。而网络游戏是游戏中的一大分支,能让玩家们…

科技“冷”战:NIST刷新制冷效率,中国实力逆境崛起!

4月23日,美国国家标准与技术研究院(NIST)的研究人员报道称,他们通过对常用于科研和工业领域的制冷机进行改装,显著降低了将材料冷却至略高于绝对零度所需的时间和能量。 科学家们指出,他们的原型设备每年能…

Linux 学习之路 -- 进程篇 -- 进程控制

目录 一、进程终止 <1>使用语言和系统自带的方法&#xff0c;进行转换 <2>自定义错误码 <3>小结&#xff1a; <2>两个接口exit / _exit 二、进程等待 <1>简单了解 <2>wait调用 <3>waitpid调用 <4>status <1>W…

复杂的字符串算法——KMP算法

字符串算法 模式匹配&#xff08;Pattern Matching&#xff09;&#xff1a;在一篇长度为 &#x1d45b; 的文本 &#x1d446; 中&#xff0c;找某个长度为 &#x1d45a; 的关键词 &#x1d443;。&#x1d443; 可能多次出现&#xff0c;都需要找到。 最优的模式匹配算法复…

AHB传输---突发操作

突发操作 在本协议中定义了4拍、8拍和16拍的突发&#xff0c;以及未定义长度的突发和单次传输。它支持增量和包装突发&#xff1a; 增量突发访问连续位置&#xff0c;每个传输的地址是前一个地址的增量。包装突发在跨越地址边界时会包装。地址边界的计算方法是突发中拍数与传…

Android—统一依赖版本管理

依赖版本管理有多种方式 config.gradle 用于Groovy DSL&#xff0c;新建一个 config.gradle 文件&#xff0c;然后将项目中所有依赖写在里面&#xff0c;更新只需修改 config.gradle文件内容&#xff0c;作用于所有module buildSrc 可用于Kotlin DSL或Groovy DSL&#xff0c;…

MATLAB冒号表示法

MATLAB 冒号表示法 colon(:)是在MATLAB中最有用的运算符之一。它用于创建向量&#xff0c;下标数组和指定迭代。 如果要创建包含1到10的整数的行向量&#xff0c;请编写- 示例 1:10 MATLAB执行该语句并返回包含1到10的整数的行向量- ans 1 2 3 4 5 6 7 8 9 10 如果要指定一…

github Copilot的使用总结

1. 代码建议和补全 GitHub Copilot 的基本使用涉及编写代码时的实时代码建议和补全。一旦你已经安装并配置好 GitHub Copilot 插件&#xff0c;你可以在支持的编辑器&#xff08;如 Visual Studio Code&#xff09;中开始使用 Copilot。以下是一些基本的使用步骤&#xff1a; …

VBA技术资料MF146:发出多次Beep提示声

我给VBA的定义&#xff1a;VBA是个人小型自动化处理的有效工具。利用好了&#xff0c;可以大大提高自己的工作效率&#xff0c;而且可以提高数据的准确度。“VBA语言専攻”提供的教程一共九套&#xff0c;分为初级、中级、高级三大部分&#xff0c;教程是对VBA的系统讲解&#…

K8S 部署和访问 Kubernetes 仪表板(Dashboard)

文章目录 部署 Dashboard UI浏览器访问登陆系统 Dashboard 是基于网页的 Kubernetes 用户界面。 你可以使用 Dashboard 将容器应用部署到 Kubernetes 集群中&#xff0c;也可以对容器应用排错&#xff0c;还能管理集群资源。 你可以使用 Dashboard 获取运行在集群中的应用的概览…

unit4.web服务的部署及高级优化方案

搭建web服务器要求如下&#xff1a; 1.web服务器的主机ip&#xff1a;172.25.254.100 [rootserver101 桌面]# vmset.sh 100 连接已成功激活&#xff08;D-Bus 活动路径&#xff1a;/org/freedesktop/NetworkManager/ActiveConnection/3&#xff09; [rootserver101 桌面]# ifc…

鑫海移民荣耀呈现:EB5投资移民盛宴落幕,卓越项目引领投资新潮

随着春日的暖阳渐渐铺满大地&#xff0c;我们鑫海移民集团在这个充满希望的季节里&#xff0c;举办了一场意义非凡的EB5投资移民专题活动。于2024年4月27日&#xff08;周六&#xff09;下午13:30&#xff0c;在北京渤海润泽威斯汀酒店隆重举行&#xff0c;我们与众多热情的参与…

基于java的商店积分管理系统的设计与实现

功能需求 从功能上可以划分为个人信息管理、商店管理、平台管理、订单管理和数据分析。后台管理系统主要服务于商户和平台管理员&#xff0c;兑换用户是属于商户平台的自有用户&#xff0c;不会被纳入到后台管理系统中来。商户用户可以对自己的积分进行管理&#xff0c;平台管…

echarts下载图片

toolbox: {show: true,//展示工具栏itemSize:20,//icon的大小iconStyle:{borderColor:"#409eff",borderWidth:"3",color:"#fff"},right:"40px",//偏移位置feature: {saveAsImage: {title: "下载图表", //鼠标滑过之后文案na…

用wps自带工具给图片做标注

在wps中&#xff0c;选中wps中的图片&#xff0c;右键选择【编辑】进入图片编辑器&#xff0c;在选项卡面板右侧选择【标注】工具&#xff0c;再选择【添加文本】工具&#xff0c;即可直接在图片上输入文字&#xff0c;标注完成后选择【覆盖原图】就完成标注任务。

【Canvas与艺术】绘制美国星条旗

注意&#xff1a; 该图位置和大小都是按照网上说明精确绘制的。 【成图】 【代码】 <!DOCTYPE html> <html lang"utf-8"> <meta http-equiv"Content-Type" content"text/html; charsetutf-8"/> <head><title>使…

FA-128晶振用于医疗设备

血糖仪已成为家庭常用的医疗设备,日本爱普生晶振公司生产的2016封装,32MHz贴片晶振可完美应用于医疗器械血糖仪,此款晶振订货型号为X1E000251005900晶振,型号为FA-128,负载电容分8PF,精度10PPM,其尺寸参数为2.0x1.6x0.5mm,符合ROHS标准且无铅,具有封装尺寸超小,高精度,频率范围…

C++ | Leetcode C++题解之第55题跳跃游戏

题目&#xff1a; 题解&#xff1a; class Solution { public:bool canJump(vector<int>& nums) {int n nums.size();int rightmost 0;for (int i 0; i < n; i) {if (i < rightmost) {rightmost max(rightmost, i nums[i]);if (rightmost > n - 1) {r…