签到系统怎么设计

背景

相信签到系统大家都有接触过,更多的是使用。但是有思考过这种系统是怎么设计的吗?比方说我统计一下每个月中每天的签到情况,怎么设计呢?今天一篇文章告诉你。

首先,我们熟悉的思维是:我设计一个数据表,实现签到的统计。

这样设计确实是可以的,但是我们仅仅作为统计的话,这样的设计就显得有点冗余了,那还有更简单的方式吗?今天就来介绍一下redis的bitmap实现这一需求。

bitmap

Redis 的 Bitmap 是一种位图数据结构,用于存储和处理位级别的数据。它使用 Redis 字符串数据类型来表示一个由二进制位组成的数组,其中每个位可以是 0 或1。它的存储结构可以用下边的这个表格展示:

0 0 0 0 0 0 1 0 1 0 0 1 0 0 1 0 1 0 1 0 1 0 0 1 0 1 0 1 1 0

Redis Bitmap 的一些常见操作:

  1. SETBIT key offset value:将指定位置的位设置为给定的值(0 或 1)。 示例:SETBIT mybitmap 0 1
  2. GETBIT key offset:返回指定位置的位的值。 示例:GETBIT mybitmap 0
  3. BITCOUNT key [start end]:计算指定范围内的位为 1 的数量。 示例:BITCOUNT mybitmap 0 -1
  4. BITOP operation destkey key [key ...]:对一个或多个位图执行逻辑运算(AND、OR、XOR、NOT)并将结果保存到目标位图中。 示例:BITOP AND destbitmap bitmap1 bitmap2

Redis 的 Bitmap 可以进行高效的位操作,所以一些常见的设计场景都可用到。如:

  • 在统计系统中,可以使用位图记录用户的活跃状态:活跃/不活跃
  • 在推荐系统中,可以使用位图记录用户的喜好标签:喜欢/不喜欢
  • 在排重场景中,可以使用位图记录已经出现过的元素

Redis 的 Bitmap 提供了一种简单而高效的方式来操作位级别的数据,并且占用的存储空间非常小。这使得它成为处理大规模位信息的理想选择。

所以,明显的第三种场景是非常适合的。今天的设计也选取了第三种场景。

测试

我们先在redis-cli中测试一下。

我操作的是第0天,我到了,第2、5天没有到,所以总共到了1天。

对应的代码设计其实和在命令行中的操作差不多,这里就不再展示了。相信以后会遇到这样的需求的,shigen也会同步的更新。


以上就是今天的分享内容啦,感谢伙伴们的阅读。

shigen一起,每天不一样!

相关推荐
许彰午11 分钟前
38_Java设计模式之装饰器模式
java·设计模式·装饰器模式
折哥的程序人生 · 物流技术专研17 分钟前
Java 23 种设计模式:从踩坑到精通 | 组合模式 —— 树形结构处理,部分与整体一视同仁
java·组合模式·java面试·springsecurity·结构型模式·java设计模式·从踩坑到精通
郝学胜-神的一滴27 分钟前
完全二叉树与堆底层原理深度剖析 | 手写C++大顶堆实现
java·开发语言·数据结构·c++·python·算法
农民小飞侠30 分钟前
[leetcode] 165. Compare Version Numbers
java·算法·leetcode
砍材农夫40 分钟前
物联网实战|Spring Boot + Netty 搭建 MQTT 消息路由与流转层
java·spring boot·后端·物联网·spring
黄毛火烧雪下44 分钟前
Java 基础笔记:文件、递归与字符编码
java·开发语言·笔记
学计算机的计算基1 小时前
链表算法上篇:LeetCode 206/234/141/142/160/21 题解与易错点
java·笔记·算法·链表
信也科技布道师1 小时前
从Istio 503 NC 错误深入理解 Mesh 路由全链路原理
java·服务器·网络
swordbob1 小时前
3 大 I/O 模型BIO / NIO / AIO
java·linux·spring
Pluto_CSND1 小时前
Cron表达式使用说明
java