濮阳杆衣贸易有限公司

主頁 > 知識(shí)庫 > 簡介Redis中的showlog功能

簡介Redis中的showlog功能

熱門標(biāo)簽:隨州營銷電話機(jī)器人怎么樣 hbuilder地圖標(biāo)注 400電話從哪里申請(qǐng)濱州 天音通信電話機(jī)器人 400電話申請(qǐng)?jiān)趺纯?/a> 杭州400電話如何申請(qǐng)的 機(jī)器人電話機(jī)創(chuàng)意繪畫 高德地圖標(biāo)注商家在哪 江西南昌百應(yīng)電話機(jī)器人

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

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

進(jìn)行設(shè)置。

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

復(fù)制代碼 代碼如下:
SLOWLOG GET 10

它將會(huì)展示一個(gè)唯一的id,時(shí)間戳和發(fā)生的查詢,查詢執(zhí)行所花掉的時(shí)間和實(shí)際被執(zhí)行的命令+參數(shù). 你可以通過SLOWLOG RESET擦出日志.


最后一次查看slowlog,我很不淡定的看到DEL命令的執(zhí)行竟然花了超過20毫秒的時(shí)間. 還記得嗎,Redis是單線程的,因此這樣會(huì)阻塞(并且嚴(yán)重的有礙)我們系統(tǒng)的并發(fā). 還有,因?yàn)檫@是一個(gè)寫操作,它將會(huì)在向所有從屬Redis服務(wù)復(fù)制的時(shí)候阻塞這一復(fù)制過程. 額,到底這是咋回事呢?

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

我們的解決方案很簡單: 不去刪除這些數(shù)據(jù)項(xiàng),而是將它們重命名,并且在后臺(tái)作業(yè)中用小而可間斷的塊去執(zhí)行對(duì)它們的刪除操作. 首先,是我們的delayed_delete函數(shù):
 

local key = KEYS[1]
local data_type = redis.call('type', key).ok
 
if data_type == 'set' or data_type == 'zset' then
 local temp = 'gc:tmp:' .. redis.call('incr', 'gc:ids') .. ':' .. key
 redis.call('rename', key, temp)
 return redis.call('sadd', 'gc:' .. data_type, temp)
end
 
return redis.call('del', key) 


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

下一步我們安排了一個(gè)Ruby腳本每分鐘運(yùn)行一次:

 

require 'redis'
r = Redis.new(driver: :hiredis)
r.srandmember('gc:set', 10000).each do |set|
 items = r.srandmember(set, 5000)
 if items.nil? || items.length == 0
  r.srem('gc:set', set)
  next
 end
 r.srem(set, items)
end
 
r.srandmember('gc:zset', 10000).each do |zset|
 if r.zremrangebyrank(zset, 0, 5000)  5000
  r.srem('gc:zset', zset)
 end
end

你可以基于自己的需要將修改數(shù)字. 你的集合有多大,以及它們被刪除有多頻繁? 因?yàn)槲覀儾蝗ヌ^頻繁的做這些類型的產(chǎn)出操作, 我們可以一次只進(jìn)行一小塊的刪除操作.

不過這種方法比直接刪除更加的慢, 但它在并發(fā)的環(huán)境下卻可以表現(xiàn)得很好.

您可能感興趣的文章:
  • Redis的11種Web應(yīng)用場景簡介
  • 簡介Lua腳本與Redis數(shù)據(jù)庫的結(jié)合使用
  • 利用Redis實(shí)現(xiàn)SQL伸縮的方法簡介
  • 在Node.js應(yīng)用中使用Redis的方法簡介
  • Redis教程(一):Redis簡介
  • NoSQL和Redis簡介及Redis在Windows下的安裝和使用教程
  • Redis簡介

標(biāo)簽:鶴崗 常德 保定 招商 葫蘆島 石嘴山 昆明 沈陽

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《簡介Redis中的showlog功能》,本文關(guān)鍵詞  簡介,Redis,中的,showlog,功能,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《簡介Redis中的showlog功能》相關(guān)的同類信息!
  • 本頁收集關(guān)于簡介Redis中的showlog功能的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    酒泉市| 宁安市| 崇文区| 德安县| 高碑店市| 许昌县| 丰县| 石嘴山市| 团风县| 凌海市| 石首市| 巩留县| 虎林市| 仁寿县| 积石山| 正定县| 肇州县| 乐至县| 广安市| 安国市| 铁岭市| 固镇县| 营山县| 宽城| 平塘县| 资阳市| 嵊州市| 阳高县| 措勤县| 梁平县| 汾阳市| 澄城县| 桓台县| 巴林左旗| 区。| 梁平县| 陈巴尔虎旗| 杭锦旗| 黑水县| 延边| 洪湖市|