麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 數據庫 > Redis > 正文

簡介Redis中的showlog功能

2020-03-17 12:42:03
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了簡介Redis中的showlog功能,作者同時對比了DEL命令的性能,需要的朋友可以參考下
 

Redis 有一個實用的slowlog功能,正如你可以猜到的,可以讓你檢查運行緩慢的查詢. Slowlog 將會記錄運行時間超過Y微秒的最后X條查詢. X 和 Y 可以在 redis.conf 或者在運行時通過 CONFIG 命令:
 
 

復制代碼代碼如下:
CONFIG SET slowlog-log-slower-than 5000
CONFIG SET slowlog-max-len 25

 

進行設置。

slowlog-log-slower-than 是用來設置微秒數的, 因此上面的設置將記錄執行時間超過5秒的查詢. 要獲取記錄的日志,你可以使用 SLOWLOG GET X 命令, 這里 X 是你想要獲取的記錄條數:
 
 

復制代碼代碼如下:
SLOWLOG GET 10

 

它將會展示一個唯一的id,時間戳和發生的查詢,查詢執行所花掉的時間和實際被執行的命令+參數. 你可以通過SLOWLOG RESET擦出日志.


最后一次查看slowlog,我很不淡定的看到DEL命令的執行竟然花了超過20毫秒的時間. 還記得嗎,Redis是單線程的,因此這樣會阻塞(并且嚴重的有礙)我們系統的并發. 還有,因為這是一個寫操作,它將會在向所有從屬Redis服務復制的時候阻塞這一復制過程. 額,到底這是咋回事呢?

也許除了我之外所有人都知道這個問題了,但是這證明了Redis的DEL命令的時間復雜度對于字符串和哈希值而言是O(1),而對于list、set和sorted set而言則是O(N) (這里的 N 是集合中數據項的數目). 你會刪除一個包含數百萬條數據的set嗎? 那就等著阻塞吧.

我們的解決方案很簡單: 不去刪除這些數據項,而是將它們重命名,并且在后臺作業中用小而可間斷的塊去執行對它們的刪除操作. 首先,是我們的delayed_delete函數:
 

  1. local key = KEYS[1] 
  2. local data_type = redis.call('type', key).ok 
  3.   
  4. if data_type == 'set' or data_type == 'zset' then 
  5.  local temp = 'gc:tmp:' .. redis.call('incr''gc:ids') .. ':' .. key 
  6.  redis.call('rename', key, temp) 
  7.  return redis.call('sadd''gc:' .. data_type, temp) 
  8. end 
  9.   
  10. return redis.call('del', key)  
 


這將會將集合重命名,并且將新的名稱添加到gc:set 或者 gc:zset set中 (我們沒有使用 list, 但如果你使用了的話,你也應該向其加入這方面的支持).

下一步我們安排了一個Ruby腳本每分鐘運行一次:

 

  1. require 'redis' 
  2. r = Redis.new(driver: :hiredis) 
  3. r.srandmember('gc:set', 10000).each do |set| 
  4.  items = r.srandmember(set, 5000) 
  5.  if items.nil? || items.length == 0 
  6.   r.srem('gc:set', set) 
  7.   next 
  8.  end 
  9.  r.srem(set, items) 
  10. end 
  11.   
  12. r.srandmember('gc:zset', 10000).each do |zset| 
  13.  if r.zremrangebyrank(zset, 0, 5000) < 5000 
  14.   r.srem('gc:zset', zset) 
  15.  end 
  16. end 
?

你可以基于自己的需要將修改數字. 你的集合有多大,以及它們被刪除有多頻繁? 因為我們不去太過頻繁的做這些類型的產出操作, 我們可以一次只進行一小塊的刪除操作.

不過這種方法比直接刪除更加的慢, 但它在并發的環境下卻可以表現得很好.


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 久久久国产一区二区三区 | 欧美中文字幕一区二区 | 中国美女一级黄色大片 | 久久国产午夜 | 免费男女视频 | 在线a免费观看 | 特大黑人videos与另类娇小 | 九艹在线 | 羞羞视频免费观看入口 | 精品一区二区免费视频视频 | 久久国产精品久久久久久久久久 | 毛片免费大全短视频 | 91久久国产露脸精品免费 | 色999中文字幕 | 日韩视频精品一区 | 免费一级毛片免费播放 | 日本免费一区二区三区四区 | 黄色羞羞 | 看一级毛片 | 福利在线国产 | 1024亚洲天堂 | 午夜精品视频免费观看 | 久久伊人精品热在75 | 美女视频在线观看黄 | 激情97 | 精品国产一区二区亚洲人成毛片 | 免费观看亚洲视频 | 欧美日韩亚洲国产 | 国产电影精品久久 | 国产精品成人一区二区三区电影毛片 | 在线中文字幕播放 | 亚洲一级片在线观看 | 欧美一区二区黄 | 欧美一级不卡视频 | 有兽焉免费动画 | 欧美成人精品一区二区男人小说 | www.99热视频 | 国产精品一区二区免费在线观看 | 国产午夜三级一区二区三桃花影视 | 国产精品.com| 国产精品视频一区二区噜噜 |