基于redis的位圖實現簽到功能

基于Redis位圖實現簽到功能是一種高效且節省內存的方法。以下是分步實現的詳細方案:

1. 鍵設計策略

采用 sign:<userId>:<YYYYMM> 格式存儲每月簽到數據

# 示例:用戶1001在2023年8月的簽到數據
sign_key = "sign:1001:202308"

2. 核心操作實現

2.1 用戶簽到
# 命令格式
SETBIT key offset 1# 示例:8月3日簽到(偏移量從0開始計算)
SETBIT sign:1001:202308 2 1
# Python偽代碼
def sign(user_id):today = datetime.now()offset = today.day - 1  # 日期轉0-based偏移量key = f"sign:{user_id}:{today.strftime('%Y%m')}"redis.setbit(key, offset, 1)
2.2 查詢簽到狀態
# 命令格式
GETBIT key offset# 示例:查詢8月3日是否簽到
GETBIT sign:1001:202308 2
def check_sign(user_id, date):offset = date.day - 1key = f"sign:{user_id}:{date.strftime('%Y%m')}"return redis.getbit(key, offset)
2.3 統計當月簽到次數
# 命令格式
BITCOUNT key# 示例:統計8月總簽到次數
BITCOUNT sign:1001:202308
2.4 獲取連續簽到天數
def get_continuous_days(user_id):today = datetime.now()key = f"sign:{user_id}:{today.strftime('%Y%m')}"max_offset = today.day - 1consecutive = 0for offset in range(max_offset, -1, -1):if redis.getbit(key, offset):consecutive += 1else:break# 檢查跨月情況if consecutive == today.day:last_day = today - timedelta(days=today.day)prev_key = f"sign:{user_id}:{last_day.strftime('%Y%m')}"prev_bits = redis.bitcount(prev_key)if prev_bits == last_day.day:consecutive += prev_bitsreturn consecutive

3. 高級功能擴展

3.1 簽到日歷生成
def get_sign_calendar(user_id, year_month):key = f"sign:{user_id}:{year_month}"value = redis.get(key) or b'\x00'# 將二進制數據轉換為位列表bits = bin(int.from_bytes(value, byteorder='big'))[2:]return [bool(int(bit)) for bit in bits.zfill(32)]  # 最多顯示31天
3.2 月度統計報告
# 獲取當月首次簽到日期
BITPOS key 1# 獲取當月最后簽到日期
BITPOS key 1 -1

4. 性能優化步驟

  1. 數據分片:對活躍用戶使用多個位圖分段存儲
  2. 緩存策略:對頻繁訪問的統計結果進行短期緩存
  3. 異步處理:非實時統計任務使用后臺進程處理
  4. 數據歸檔:定期將歷史數據轉存到持久化存儲

5. 異常處理機制

  1. 日期有效性驗證:
def validate_date(year, month, day):try:datetime(year, month, day)return Trueexcept ValueError:return False
  1. 偏移量范圍檢查:
max_day = calendar.monthrange(year, month)[1]
if offset >= max_day:raise InvalidOffsetError("超出當月天數范圍")

6. 數據可視化示例

生成簽到日歷JSON:

{"202308": {"total": 18,"continuous": 5,"calendar": [{"day": 1, "signed": true},{"day": 2, "signed": false},...]}
}

7. 內存使用估算

假設:

  • 每月最大31天
  • 每個用戶每月占用4字節(31位)
  • 10萬活躍用戶

總內存消耗:100,000用戶 × 12月 × 4字節 ≈ 4.8MB

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/72261.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/72261.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/72261.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

C++ Qt OpenGL渲染FFmpeg解碼后的視頻

本篇博客介紹使用OpenGL渲染FFmpeg解碼后的視頻,涉及到QOpenGLWidget、QOpenGLFunctions、OpenGL shader以及紋理相關,播放效果如下: 開發環境:Win11 C++ Qt6.8.1、FFmpeg4.0、x64 ??注意:Qt版本不同時,Qt OpenGL API及用法可能差別比較大,FFmpeg版本不同時API調用可能…

deepseek部署:ELK + Filebeat + Zookeeper + Kafka

## 1. 概述 本文檔旨在指導如何在7臺機器上部署ELK&#xff08;Elasticsearch, Logstash, Kibana&#xff09;堆棧、Filebeat、Zookeeper和Kafka。該部署方案適用于日志收集、處理和可視化場景。 ## 2. 環境準備 ### 2.1 機器分配 | 機器編號 | 主機名 | IP地址 | 部署組件 |-…

2.數據結構:1.Tire 字符串統計

1.Tire 字符串統計 #include<algorithm> #include<cstring> #include<iostream>using namespace std;const int N100010; int son[N][26];//至多 N 層&#xff0c;每一層至多 26 個節點&#xff08;字母&#xff09; int cnt[N];//字符串至多 N 個&#xff…

算法(四)——位運算與位圖

文章目錄 位運算、位圖位運算基本位運算異或運算交換兩個數無比較返回最大值缺失的數字唯一出現奇數次的數唯二出現奇數次的數唯一出現次數少于m次的數 位運算進階判斷一個整數是不是2的冪判斷一個整數是不是3的冪大于等于n的最小的2的冪[left, right]內所有數字&的結果反轉…

本地部署deepseek大模型后使用c# winform調用(可離線)

介于最近deepseek的大火&#xff0c;我就在想能不能用winform也玩一玩本地部署&#xff0c;于是經過查閱資料&#xff0c;然后了解到ollama部署deepseek,最后用ollama sharp NUGet包來實現winform調用ollama 部署的deepseek。 本項目使用Vs2022和.net 8.0開發&#xff0c;ollam…

SpringBoot原理-02.自動配置-概述

一.自動配置 所謂自動配置&#xff0c;就是Spring容器啟動后&#xff0c;一些配置類、bean對象就自動存入了IOC容器當中&#xff0c;而不需要我們手動聲明&#xff0c;直接從IOC容器中引入即可。省去了繁瑣的配置操作。 我們可以首先將spring項目啟動起來&#xff0c;里面有一…

P10265 [GESP樣題 七級] 迷宮統計

題目描述 在神秘的幻想?陸中&#xff0c;存在著 n 個古老而神奇的迷宮&#xff0c;迷宮編號從 1 到 n。有的迷宮之間可以直接往返&#xff0c;有的可以?到別的迷宮&#xff0c;但是不能?回來。玩家小楊想挑戰?下不同的迷宮&#xff0c;他決定從 m 號迷宮出發。現在&#x…

Spring框架中的工廠模式

在Spring框架里&#xff0c;工廠模式的運用十分廣泛&#xff0c;它主要幫助我們創建和管理對象&#xff0c;讓對象的創建和使用分離&#xff0c;提高代碼的可維護性和可擴展性。下面為你詳細介紹Spring框架中工廠模式的具體體現和示例&#xff1a; 1. BeanFactory 作為工廠模式…

音視頻-WAV格式

1. WAV格式說明&#xff1a; 2. 格式說明&#xff1a; chunkId&#xff1a;通常是 “RIFF” 四個字節&#xff0c;用于標識文件類型。&#xff08;wav文件格式表示&#xff09;chunkSize&#xff1a;表示整個文件除了chunkId和chunkSize這 8 個字節外的其余部分的大小。Forma…

SQL Server Management Studio的使用

之前在https://blog.csdn.net//article/details/140961550介紹了在Windows10上安裝SQL Server 2022 Express和SSMS&#xff0c;這里整理下SSMS的簡單使用&#xff1a; SQL Server Management Studio(SSMS)是一種集成環境&#xff0c;提供用于配置、監視和管理SQL Server和數據…

數據集筆記:NUSMods API

1 介紹 NUSMods API 包含用于渲染 NUSMods 的數據。這些數據包括新加坡國立大學&#xff08;NUS&#xff09;提供的課程以及課程表的信息&#xff0c;還包括上課地點的詳細信息。 可以使用并實驗這些數據&#xff0c;它們是從教務處提供的官方 API 中提取的。 該 API 由靜態的…

劍指 Offer II 031. 最近最少使用緩存

comments: true edit_url: https://github.com/doocs/leetcode/edit/main/lcof2/%E5%89%91%E6%8C%87%20Offer%20II%20031.%20%E6%9C%80%E8%BF%91%E6%9C%80%E5%B0%91%E4%BD%BF%E7%94%A8%E7%BC%93%E5%AD%98/README.md 劍指 Offer II 031. 最近最少使用緩存 題目描述 運用所掌握的…

uniapp 測試 IPA 包安裝到測試 iPhone

將uniapp測試IPA包安裝到測試iPhone有以下幾種方法&#xff1a; 使用Xcode安裝 確保計算機上安裝了Xcode&#xff0c;并將iOS設備通過數據線連接到計算機。打開Xcode&#xff0c;在菜單欄中選擇Window->Devices and Simulators&#xff0c;在設備列表中找到要安裝的iPhone…

vcredist_x64 資源文件分享

vcredist_x64 是 Microsoft Visual C Redistributable 的 64 位版本&#xff0c;用于在 64 位 Windows 系統上運行使用 Visual C 開發的應用程序。它包含了運行這些應用程序所需的運行時組件。 vcredist_x64 資源工具網盤下載鏈接&#xff1a;https://pan.quark.cn/s/ef56f838f…

weaviate 安裝與測試

weaviate 安裝 前提條件&#xff1a;docker安裝完成 步驟&#xff1a; 開啟docker 在終端運行命令 docker run -p 8080:8080 -p 50051:50051 cr.weaviate.io/semitechnologies/weaviate:1.29.0 weaviate 測試 python-client安裝代碼測試 import weaviate client weaviat…

機器學習:監督學習、無監督學習和強化學習

機器學習&#xff08;Machine Learning, ML&#xff09;是人工智能&#xff08;AI&#xff09;的一個分支&#xff0c;它使計算機能夠從數據中學習&#xff0c;并在沒有明確編程的情況下執行任務。機器學習的核心思想是使用算法分析數據&#xff0c;識別模式&#xff0c;并做出…

自學微信小程序的第六天

DAY6 1、使用錄音API首先需要通過wx.getRecorderManager()方法獲取到一個RecorderManager實例,該實例是一個全局唯一的錄音管理器,用于實現錄音功能。 表32:RecorderManager實例的常用方法 方法名稱 說明 start() 開始錄音 pause() 暫停錄音 resume() 繼續錄音 stop() 停止…

【數據分析】上市公司市場勢力數據測算+dofile(1992-2023年)

市場勢力通常指的是公司在市場中的相對競爭力和定價能力。具有較強市場勢力的公司通常能夠控制價格、影響市場規則&#xff0c;并在競爭中占據主導地位。A股公司市場勢力數據是對中國資本市場中公司競爭力的深入分析&#xff0c;A股市場中&#xff0c;公司市場勢力的強弱不僅影…

Linux三種網絡方式

前言 發現運維啥都得會&#xff0c;這周就遇到了網絡問題自己無法解決&#xff0c;因此痛定思痛學一下。 參考文獻 你管這破玩意叫網絡&#xff1f; 橋接模式、NAT模式、僅主機模式&#xff0c;原來是這樣工作的 交換機 構成局域網&#xff0c;實現所有設備之間的通信。 …

DeepSeek + Mermaid編輯器——常規繪圖

下面這張圖出自&#xff1a;由清華大學出品的 《DeepSeek&#xff1a;從入門到精通》。 作為純文本生成模型&#xff0c;DeepSeek雖不具備多媒體內容生成接口&#xff0c;但其開放式架構允許通過API接口與圖像合成引擎、數據可視化工具等第三方系統進行協同工作&#xff0c;最終…