java redis计数器,redis:每天重置计数器

本文探讨了如何在多进程环境中利用Redis实现每日重置的计数器,确保每次操作的唯一性。通过示例代码展示了在Python中使用Redis的事务和Lua脚本来原子性地更新和重置计数器,以此避免潜在的竞态条件问题。
摘要由CSDN通过智能技术生成

I am looking to reset a counter every day using Redis. I am new to Redis so I want to make sure I well understood how transactions and pipes work.

Does the following code ensure that I will always get a unique couple of (date, number) while working in a multi processes environment or do I need to use a Redis lock?

import datetime

import redis

r = redis.Redis(...)

def get_utc_date_now():

return datetime.datetime.utcnow().date()

def get_daily_counter(r, dt_key='dt', counter_key='counter'):

def incr_daily_number(pipe):

dt_now = get_utc_date_now().isoformat() # e.g.: "2014-10-18"

dt = pipe.get(dt_key)

pipe.multi()

if dt != dt_now:

pipe.set(dt_key, dt_now)

pipe.set(counter_key, 0)

pipe.get(dt_key)

pipe.incr(counter_key)

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值