示例如下:
import redis import time def event_handler(msg): ''' 监听到任何key过期后,得到的消息如下 msg ={'type': 'pmessage', #返回值类型 'pattern': '__keyevent@2__:expired', #来源 'channel': '__keyevent@2__:expired', # 实际的Channel 'data': 'mykey' # key名称 } 可以根据您要监控的key进行业务判断或触发其他事件 if msg['data']=='mykey': do.... elif msg['data']=='yourkey': do ---- ''' print(msg) redis_conn = redis.Redis(host='host', port='6379', db=2, password='test.123.com', decode_responses=True) #设置过期时间2秒 redis_conn.set('mykey', 'asjdhkjashdkjahdskjahsd', ex=2) # 订阅消息 pubsub =redis_conn.pubsub() # 订阅key过期事件 # __keyevent@2__:expired : __keyevent@{db}__:事件 pubsub.psubscribe(**{'__keyevent@2__:expired': event_handler}) while True: message = pubsub.get_message() if message: # redis_conn.set('mykey', 'asjdhkjashdkjahdskjahsd', ex=10) print('wqwqwqwqwqwqwqwqwqwqwqwqwqwqwqwqwqwq') else: time.sleep(0.01)
登录后复制
以上就是如何利用redis实现倒计时任务的详细内容,更多请关注Work网其它相关文章!