欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

簡介Redis中的showlog功能

 更新時間:2015年06月29日 15:02:17   投稿:goldensun  
這篇文章主要介紹了簡介Redis中的showlog功能,作者同時對比了DEL命令的性能,需要的朋友可以參考下

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

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

進行設(shè)置。

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

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

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


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

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

我們的解決方案很簡單: 不去刪除這些數(shù)據(jù)項,而是將它們重命名,并且在后臺作業(yè)中用小而可間斷的塊去執(zhí)行對它們的刪除操作. 首先,是我們的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) 


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

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

 

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ù)字. 你的集合有多大,以及它們被刪除有多頻繁? 因為我們不去太過頻繁的做這些類型的產(chǎn)出操作, 我們可以一次只進行一小塊的刪除操作.

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

相關(guān)文章

  • 單線程Redis快的4 個原因總結(jié)

    單線程Redis快的4 個原因總結(jié)

    作為內(nèi)存中數(shù)據(jù)存儲,Redis 以其速度和性能著稱,通常被用作大多數(shù)后端服務(wù)的緩存解決方案,但是,在內(nèi)部,Redis 采用單線程架構(gòu),為什么單線程設(shè)計依然會有這么高的性能,在本文中,讓我們深入探討為什么 Redis 才有單線程架構(gòu)
    2023-07-07
  • 詳解redis在微服務(wù)領(lǐng)域的貢獻

    詳解redis在微服務(wù)領(lǐng)域的貢獻

    本文以dubbo為例看下redis是如何利用自身特性來完成注冊中心的功能,對redis微服務(wù)相關(guān)知識感興趣的朋友一起看看吧
    2021-10-10
  • Redis GEO地理信息定位功能

    Redis GEO地理信息定位功能

    Redis 提供了GEO地理信息定位功能,地理空間項(經(jīng)度、緯度、名稱),實現(xiàn)查找附近的人、上班打卡、自行車租賃、搖一搖等相關(guān)與地理位置信息的功能,這篇文章主要介紹了Redis GEO地理信息定位功能,需要的朋友可以參考下
    2023-12-12
  • redis使用Lua腳本解決多線程下的超賣問題及原因解析

    redis使用Lua腳本解決多線程下的超賣問題及原因解析

    這篇文章主要介紹了redis使用Lua腳本解決多線程下的超賣問題,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-05-05
  • 讓Redis在你的系統(tǒng)中發(fā)揮更大作用的幾點建議

    讓Redis在你的系統(tǒng)中發(fā)揮更大作用的幾點建議

    Redis在很多方面與其他數(shù)據(jù)庫解決方案不同:它使用內(nèi)存提供主存儲支持,而僅使用硬盤做持久性的存儲;它的數(shù)據(jù)模型非常獨特,用的是單線程。另一個大區(qū)別在于,你可以在開發(fā)環(huán)境中使用Redis的功能,但卻不需要轉(zhuǎn)到Redis
    2014-06-06
  • Redis的Sentinel解決方案介紹與運行機制

    Redis的Sentinel解決方案介紹與運行機制

    這篇文章主要介紹了Redis的Sentinel解決方案介紹與運行機制, Sentinel 是一款面向分布式服務(wù)架構(gòu)的輕量級流量控制組件,主要以流量為切入點,從流量控制、熔斷降級、系統(tǒng)自適應(yīng)保護等多個維度來保障服務(wù)的穩(wěn)定性,需要的朋友可以參考下
    2023-07-07
  • 在Mac OS上安裝Vagrant和Docker的教程

    在Mac OS上安裝Vagrant和Docker的教程

    這篇文章主要介紹了在Mac OS上安裝Vagrant和Docker的教程,并安裝和設(shè)置Postgres和Elasticsearch和Redis,需要的朋友可以參考下
    2015-04-04
  • caffeine_redis自定義二級緩存

    caffeine_redis自定義二級緩存

    這篇文章詳細介紹了caffeine_redis 自定義二級緩存,文中有相關(guān)的背景前提與出現(xiàn)的問題,感興趣的同學(xué)可以參考一下
    2023-04-04
  • Redis如何實現(xiàn)延遲隊列

    Redis如何實現(xiàn)延遲隊列

    這篇文章主要介紹了Redis如何實現(xiàn)延遲隊列問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • 基于Redis實現(xiàn)每日登錄失敗次數(shù)限制

    基于Redis實現(xiàn)每日登錄失敗次數(shù)限制

    這篇文章主要介紹了通過redis實現(xiàn)每日登錄失敗次數(shù)限制的問題,通過redis記錄登錄失敗的次數(shù),以用戶的username為key,本文給出了實例代碼,需要的朋友可以參考下
    2019-08-08

最新評論