服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|数据库技术|

服务器之家 - 数据库 - Redis - Redis 除了用作缓存还能干吗?

Redis 除了用作缓存还能干吗?

2023-12-11 15:11ByteByteGo Redis

Redis 的最常用的用例是缓存,以加快网络应用的速度。在这种用例中,Redis 将经常请求的数据存储在内存中。它允许网络服务器频繁访问的数据。这就减少了数据库的负载,并缩短应用程序的响应时间。在大规模应用中,缓存分布

今天我们来聊聊 Redis 的使用案例。

Redis 是一种内存键值数据库。它支持多种数据结构,如 String, Hash, List, Set 和 SortedSet。

Redis 除了用作缓存还能干吗?图片

01 缓存

Redis 的最常用的用例是缓存,以加快网络应用的速度。在这种用例中,Redis 将经常请求的数据存储在内存中。它允许网络服务器频繁访问的数据。这就减少了数据库的负载,并缩短应用程序的响应时间。在大规模应用中,缓存分布在 Redis 服务器集群中。

Redis 作为分布式缓存时需要考虑的其他问题包括:

  • 设置正确的 TTL (Time to Live)
  • 处理冷启动时对数据库的密集访问

02 Session 存储

另一个常见用例是将 Redis 用作 Session 存储,在无状态服务之间共享 Session 数据。

当用户登录网络应用程序时,服务端会创建一个唯一的 Session ID,Session 数据会存储在 Redis 中,然后 Session 作为 Cookie 的一部分返回给客户端。

当用户向应用程序发出请求时,Session ID 会包含在请求中。无状态网络服务器会使用 Session 数据。值得注意的是 Redis 是内存数据库。如果 Redis 服务器重启,存储在 Redis 中的 Session 数据会丢失。

即使 Redis 提供了 RDB 和 AOF 等持久化选项,但这些选项在重启时加载数据的时间往往太长,不实用。在实际生产环境中,数据会复制到备份实例。如果主实例崩溃,备份迅速升级,接管流量。

03 分布式锁

需要协调对某些共享资源的访问时,就会使用分布式锁。Redis 通过其原子命令(如 SETNX, SET if Not eXists)来做分布式锁。它允许调用者设置一个不存在的键。

比如,客户端通过设置一个唯一的 Key 来获取锁:

SETNX lock "1234abcd" EX 3

如果 Key 尚未设置,SETNX 命令返回 1,表明锁已被客户端获取。客户端完成工作后 删除 Key ,释放锁。

如果 Key 已被设置,SETNX 命令返回 0,表明锁已被其他客户机持有。在这种情况下,客户端会等待并重试 SETNX 操作,直到锁被其他客户端释放。

请注意,这种简单的实现对于许多用例来说已经足够好了,但并非完全容错。对于生产应用,许多 Redis 客户端库提供高质量的分布式锁实现。

04 限流

Redis 可用作限流。一个非常基本的限流算法是这样工作的:

对于每个用户请求,其请求的 IP 或用户 ID 用作 Key。每个请求都会使键值递增。将当前计数与允许的速率限制进行比较,如果计数在速率限制范围内,则处理请求。如果计数超过速率限制,则拒绝请求。Key可以设置为在特定时间窗口(如一分钟)后过期,以重置下一个时间窗口的计数。

05 游戏排行榜

对于大多数规模不是很大的游戏来说,Redis 是一种很好的实现方式。SortedSet 是实现这一功能的基本数据结构。

SortedSet 的每个元素都有一个与之相关的分数。元素按分数排序。这样就可以在对数时间内 完成排序。

06 购物车

我们可以使用 Hash 来表示购物车中的键值对。对于简单的电商平台来说,在 Redis 中实现购物车可以兼顾用户体验和快速交付。

07 计算用户留存率

我们可以使用 Bitmap 来表示每天登录的用户并计算用户保留率。这种计数功能占用的内存很少。

08 消息队列

我们可以使用 List 来做消息队列。也可以使用 Redis 的 PubSub 功能来实现类似的消息总线功能。

原文地址:https://mp.weixin.qq.com/s/FgMNDAB9YnfKhu03fZMZhA

延伸 · 阅读

精彩推荐
  • Redisredis数据结构之intset的实例详解

    redis数据结构之intset的实例详解

    这篇文章主要介绍了redis数据结构之intset的实例详解的相关资料, intset也即整数集合,当集合保存的值数量不多时,redis使用intset作为其底层数据保存结构,...

    爱宝贝丶3132019-11-08
  • Redis详解Redis 分布式锁遇到的序列化问题

    详解Redis 分布式锁遇到的序列化问题

    这篇文章主要介绍了Redis 分布式锁遇到的序列化问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下...

    WriteOnRead9252021-07-29
  • RedisCentOS系统下Redis安装和自启动配置的步骤

    CentOS系统下Redis安装和自启动配置的步骤

    相信大家都知道Redis是一个C实现的基于内存、可持久化的键值对数据库,在分布式服务中常作为缓存服务。所以这篇文章将详细介绍在CentOS系统下如何从零...

    daisy2882019-10-30
  • Redis如何使用Redis实现电商系统的库存扣减

    如何使用Redis实现电商系统的库存扣减

    在日常开发中有很多地方都有类似扣减库存的操作,本文主要介绍了如何使用Redis实现电商系统的库存扣减,具有一定的参考价值,感兴趣的可以了解一下...

    PHP开源社区6412022-02-10
  • RedisRedis使用ZSET实现消息队列使用小结

    Redis使用ZSET实现消息队列使用小结

    这篇文章主要介绍了Redis使用ZSET实现消息队列使用总结,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下...

    香吧香11402023-03-19
  • RedisRedis内存淘汰和过期删除策略原理分析

    Redis内存淘汰和过期删除策略原理分析

    在实际使用过程中,过期时间配置只是一种常规手段,当key的数量在短时间内突增,就有可能导致内存不够用。此时就需要依赖于Redis内部提供的淘汰策略...

    政采云技术6982023-10-26
  • Redisredis中5种数据基础查询命令

    redis中5种数据基础查询命令

    本文主要介绍了redis中5种数据基础查询命令,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着...

    测试小菜鸟_ccc3612023-04-14
  • Redis玩转Redis搭建集群之Sentinel详解

    玩转Redis搭建集群之Sentinel详解

    这篇文章主要给大家介绍了关于Redis搭建集群之Sentinel的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需...

    Jackeyzhe2862019-11-20