学生程序设计能力提升平台源码分析(十二)redis使用

前言

2021SC@SDUSC

概述

本次博客将围绕redis来讲,大概内容包括redis的基础,安装配置,使用方法,以及在项目中可能的应用等。

可以加一些redis底层原理的分析哈,不过这部分我只是略有耳闻,会拿一些别人的东西作为参考。

因为实际项目开发中并未使用redis,所以在这里更多的是对redis在实际项目使用场景的设想,偏向于理论层面。

因为redis可以说是业界常用了,咱也不怎么会创新,这里大部分就是前人的东西,拿来用一下。

下面开始正文部分。

redis

简介

经典非关系型数据库哈,相信大家都比较熟悉了。定义如下:

Redis 是完全开源的,遵守 BSD 协议,是一个高性能的 key-value 数据库。

Redis 与其他 key - value 缓存产品有以下三个特点:

  • Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。
  • Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储。
  • Redis支持数据的备份,即master-slave模式的数据备份。

优势

  • 性能极高 – Redis能读的速度是110000次/s,写的速度是81000次/s 。
  • 丰富的数据类型 – Redis支持二进制案例的 Strings, Lists, Hashes, Sets 及 Ordered Sets 数据类型操作。
  • 原子 – Redis的所有操作都是原子性的,意思就是要么成功执行要么失败完全不执行。单个操作是原子性的。多个操作也支持事务,即原子性,通过MULTI和EXEC指令包起来。
  • 丰富的特性 – Redis还支持 publish/subscribe, 通知, key 过期等等特性。

区别于其他k-v存储

  • Redis有着更为复杂的数据结构并且提供对他们的原子性操作,这是一个不同于其他数据库的进化路径。Redis的数据类型都是基于基本数据结构的同时对程序员透明,无需进行额外的抽象。

  • Redis运行在内存中但是可以持久化到磁盘,所以在对不同数据集进行高速读写时需要权衡内存,因为数据量不能大于硬件内存。在内存数据库方面的另一个优点是,相比在磁盘上相同的复杂的数据结构,在内存中操作起来非常简单,这样Redis可以做很多内部复杂性很强的事情。同时,在磁盘格式方面他们是紧凑的以追加的方式产生的,因为他们并不需要进行随机访问。

安装配置

安装

Windows可参考windows下Redis的安装和配置--图文教程_Zepal-CSDN博客_redis安装教程

Linux可参考Linux安装部署Redis(超级详细) - 长沙大鹏 - 博客园

也可参考Redis 安装_架构师必备技能-CSDN博客

配置

可参考Redis 配置_架构师必备技能-CSDN博客

简单,不再赘述。

基本使用

java简单使用

Java 使用 Redis_架构师必备技能-CSDN博客

springboot中的简单使用

Springboot中使用Redis - 陆上江南 - 博客园

应用场景

11种web应用场景参考自Redis 11种Web应用场景举例_Smile_@的博客-CSDN博客

下面列出11种web应用场景,在这些场景下可以充分的利用redis的特性,大大提高效率。

1.在主页中显示最新的项目列表。

redis使用的是常驻内存的缓存,速度非常快。lpush用来插入一个内容id,作为关键字存储在列表头部。ltrim用来限制列表中的项目数最多为5000。如果用户需要的检索的数据量超越这个缓存容量,这时才需要把请求发送到数据库。

2.删除和过滤。

如果一篇文章被删除,可以使用lrem从缓存中彻底清除掉。

3.排行榜及相关问题。

排行榜(leader board)按照得分进行排序。zadd命令可以直接实现这个功能,而zrevrange命令可以用来按照得分来获取前100名的用户,zrank可以用来获取用户排名,非常直接而且操作容易。

4.按照用户投票和时间排序。

这就像reddit的排行榜,得分会随着时间变化。lpush和ltrim命令结合运用,把文章添加到一个列表中。一项后台任务用来获取列表,并重新计算列表的排序,zadd命令用来按照新的顺序填充生成列表。列表可以实现非常快速的检索,即使是负载很重的站点。

5.过期项目处理。

使用unix时间作为关键字,用来保持列表能够按时间排序。对current_time和time_to_live进行检索,完成查找过期项目的艰巨任务。另一项后台任务使用zrange…withscores进行查询,删除过期的条目。

6.计数。

进行各种数据统计的用途是非常广泛的,比如想知道什么时候封锁一个ip地址。incrby命令让这些变得很容易,通过原子递增保持计数;getset用来重置计数器;过期属性用来确认一个关键字什么时候应该删除。

7.特定时间内的特定项目。

这是特定访问者的问题,可以通过给每次页面浏览使用sadd命令来解决。sadd不会将已经存在的成员添加到一个集合。

8.实时分析正在发生的情况,用于数据统计与防止垃圾邮件等。

使用redis原语命令,更容易实施垃圾邮件过滤系统或其他实时跟踪系统。

9.pub/sub。

在更新中保持用户对数据的映射是系统中的一个普遍任务。redis的pub/sub功能使用了subscribe、unsubscribe和publish命令,让这个变得更加容易。

10.队列。

在当前的编程中队列随处可见。除了push和pop类型的命令之外,redis还有阻塞队列的命令,能够让一个程序在执行时被另一个程序添加到队列。你也可以做些更有趣的事情,比如一个旋转更新的rss feed队列。

11.缓存。

redis缓存使用的方式与memcache相同。

网络应用不能无休止地进行模型的战争,看看这些redis的原语命令,尽管简单但功能强大,把它们加以组合,所能完成的就更无法想象。当然,你可以专门编写代码来完成所有这些操作,但redis实现起来显然更为轻松。

一些详细例子:

Redis常见的使用场景_allen的博客-CSDN博客_redis使用场景举例

参考Redis-使用场景_sinat_27143551的博客-CSDN博客_redis使用场景

可以看到,redis在项目中的使用场景是非常广泛的。

进阶知识

Redis使用总结(一、几点使用心得)_架构师必备技能-CSDN博客_redis使用

Redis使用总结(二、缓存和数据库双写一致性问题)_架构师必备技能-CSDN博客_缓存和数据库双写一致性问题


Redis使用总结(三、缓存击穿问题)_架构师必备技能-CSDN博客
 

Redis使用总结(四、处理延时任务)_架构师必备技能-CSDN博客_redis 时间轮

参考资料

Redis 简介 | 菜鸟教程

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值