針對永久不過時的key 批量設置過時時間

問題需求:
  redis內存暴增,後來發現有不少設置永久不過時。

解決:查找出來以後針對前綴批量設置過時時間 (過時時間與開發溝通 保證服務不受影響)

來源於網上楊一的代碼 正好解決了我遇到的問題 在這裏記錄一下。

1
# encoding: utf-8 2 3 import redis 4 import random 5 import string 6 import time 7 pool = redis.ConnectionPool(host='127.0.0.1', port=6379, password="123456", db=0) 8 r = redis.Redis(connection_pool=pool) 9 10 def random_str(): 11 return ''.join(random.choice(string.ascii_letters + string.digits) for _ in range(7)) 12 13 14 def init_keys(): 15 start_time = time.time() 16 for i in xrange(0, 20): 17 key_name = 'dba_'+str(i) 18 value_name = random_str() 19 r.set(key_name, value_name) 20 print 'initial keys successfully,use time:', time.time() - start_time 21 22 23 def del_keys_without_pipe(): 24 start_time = time.time() 25 result_length = 0 26 for key in r.scan_iter(match='rawdata_lastStatus_0015000200*', count=1000): 27 r.delete(key) 28 result_length += 1 29 print "normal ways end at:", time.time() - start_time 30 print "normal ways delete numbers:", result_length 31 32 33 def del_keys_with_pipe(): 34 start_time = time.time() 35 result_length = 0 36 pipe = r.pipeline() 37 for key in r.scan_iter(match='rawdata_*_otherTrades', count=1000): 38 pipe.expire(key,120) 39 result_length += 1 40 if result_length % 1000 == 0: 41 pipe.execute() 42 time.sleep(1) 43 pip_time = time.time() 44 print "use pipeline scan time ", time.time() - start_time 45 pipe.execute() 46 47 print "use pipeline end at:", time.time() - pip_time 48 print "use pipeline ways delete numbers:", result_length 49 50 51 def main(): 52 # init_keys() 53 # del_keys_without_pipe() 54 # init_keys() 55 del_keys_with_pipe() 56 57 58 if __name__ == '__main__': 59 main()
相關文章
相關標籤/搜索