当前位置: 首页 > 编程笔记 >

Redis的使用模式之计数器模式实例

太叔昆
2023-03-14
本文向大家介绍Redis的使用模式之计数器模式实例,包括了Redis的使用模式之计数器模式实例的使用技巧和注意事项,需要的朋友参考一下

Redis 是目前 NoSQL 领域的当红炸子鸡,它象一把瑞士军刀,小巧、锋利、实用,特别适合解决一些使用传统关系数据库难以解决的问题。打算写一系列 Redis 使用模式的文章,深入总结介绍 Redis 常见的使用模式,以供大家参考。

常见汇总计数器

汇总计数是系统常见功能,比如网站通常需要统计注册用户数,网站总浏览次数等等。 使用 Redis 提供的基本数据类型就能实现汇总计数器,通过 incr 命令实现增加操作。

比如注册用户数,基本操作命令如下:


 # 获取注册用户数

  get total_users

  # 注册用户数增加一位

  incr total_users

按时间汇总的计数器

通常计数还要按时间统计,比如注册用户数需要按日统计,处理方法比较简单,把日期带入计数器 key 就可以。

还是注册用户计数的例子,基本操作命令如下:


# 假定操作 2014-07-06 数据

  # 获取注册用户数

  get total_users:2014-07-06

  # 2014-07-06 注册用户数增加一位

  incr total_users:2014-07-06

  # 设置 48 小时过期时间 172800 = 48 * 60 * 60

  expire total_users:2014-07-06 172800

为计数器设置一个 48 小时的过期时间是为了节省计数器占用空间,毕竟 redis 是内存数据库,可以在过期前执行一个任务把计数器存入关系数据库。

速度控制

速度控制也是 Redis 一种常见的计数用途,比如有一个 API 服务,希望控制每一个 IP 每秒请求数不超过 10 次,可以用 IP 和 时间秒作为 key 设置一个计数器,实现控制,伪代码如下所示:


 # 每秒最大请求数

  MAX_REQUESTS_PER_SECOND = 10

  # 检查 ip 请求限制   # @param ip   # @raise 超过限制,抛出 RuntimeError 异常

  def check_request_limitation_for_ip(ip)     time_tick = Time.now.to_i     key = "#{ip}:#{time_tick}"     num = $redis.get(key).to_i     if num > MAX_REQUEST_PER_SECOND       raise 'too many requests'     else       $redis.incr(key)       $redis.expire(key, 10)     end   end

使用 Hash 数据类型维护大量计数器

有时候需要维护大量计数器,比如每一个论坛主题的查看数,比如每一个用户访问页面次数,因为论坛主题和用户基数可能很大,直接基于论坛主题或用户 ID 生成计数器的话,占用 Redis 资源还是相当可观的,这时可以用 Hash 数据类型压缩所需资源。

比如,对应论坛主题查看计数,可以由模式


  key: topic:<topic_id>:views

  value: view count (integer)

转换为模式:


 key: topic:views

  value: hash

    hash key: <topic_id>

    hash value: view count (integer)

总结:利用 Redis 实现计数器,可以简单高效实现各种计数功能。

 类似资料:
  • 介绍 适配器模式(Adapter)是将一个类(对象)的接口(方法或属性)转化成客户希望的另外一个接口(方法或属性),适配器模式使得原本由于接口不兼容而不能一起工作的那些类(对象)可以一些工作。速成包装器(wrapper)。 正文 我们来举一个例子,鸭子(Dock)有飞(fly)和嘎嘎叫(quack)的行为,而火鸡虽然也有飞(fly)的行为,但是其叫声是咯咯的(gobble)。如果你非要火鸡也要实现

  • 介绍 迭代器模式(Iterator):提供一种方法顺序一个聚合对象中各个元素,而又不暴露该对象内部表示。 迭代器的几个特点是: 访问一个聚合对象的内容而无需暴露它的内部表示。 为遍历不同的集合结构提供一个统一的接口,从而支持同样的算法在不同的集合结构上进行操作。 遍历的同时更改迭代器所在的集合结构可能会导致问题(比如C#的foreach里不允许修改item)。 正文 一般的迭代,我们至少要有2个方

  • 本文向大家介绍PHP设计模式之适配器模式代码实例,包括了PHP设计模式之适配器模式代码实例的使用技巧和注意事项,需要的朋友参考一下 目标: 可将一个类的接口转换成客户希望的另外一个接口,使得原本不兼容的接口能够一起工作。通俗的理解就是将不同接口适配成统一的API接口。 角色: Target适配目标,该角色定义把其他类转换为何种接口,也就是我们的期望接口。 Adaptee被适配者,就是需要被适配的接

  • 本文向大家介绍c#设计模式之单例模式的实现方式,包括了c#设计模式之单例模式的实现方式的使用技巧和注意事项,需要的朋友参考一下 场景描述 单例模式对于我们来说一点也不模式,是一个常见的名称,单例模式在程序中的实际效果就是:确保一个程序中只有一个实例,并提供一个全局访问点,节省系统资源 单例模式无论是在实际开发中还是在软件应用中比较常见,比如,windows系统的任务管理器、IIS的HttpAppl

  • 本文向大家介绍JavaScript设计模式之单例模式实例,包括了JavaScript设计模式之单例模式实例的使用技巧和注意事项,需要的朋友参考一下 《Practical Common Lisp》的作者 Peter Seibel 曾说,如果你需要一种模式,那一定是哪里出了问题。他所说的问题是指因为语言的天生缺陷,不得不去寻求和总结一种通用的解决方案。 不管是弱类型或强类型,静态或动态语言,命令式或说

  • 本文向大家介绍JavaScript设计模式之外观模式实例,包括了JavaScript设计模式之外观模式实例的使用技巧和注意事项,需要的朋友参考一下 外观模式(门面模式),是一种相对简单而又无处不在的模式。外观模式提供一个高层接口,这个接口使得客户端或子系统更加方便调用。 用一段再简单不过的代码来表示: 如果你需要分别调用getName和getSex函数. 那可以用一个更高层的接口getUserIn