慢查詢日誌
什麼是SLOW LOG?
Slow log是Redis用來記錄查詢執行時間超過給定時長的命令請求的日誌系統。查詢執行時間指的是不包括像客戶端回應(talking)、發送回應等IO操作,而單單是執行一個查詢命令所耗費的時間。另外,slow log保存在記憶體裡面,讀寫速度非常快,因此你可以放心地使用它,不必擔心因為開啟slow log而損害Redis的速度。

設定和檢視SLOWLOG
伺服器設定有兩個和慢查詢日誌相關的選項:
slowlog-log-slower- than:選項指定執行時間超過多少微秒(1秒等於1,000,000微秒)的指令請求會被記錄到日誌上。舉個例子, 如果這個選項的值為100,那麼執行時間超過100微秒的指令就會被記錄到慢查詢日誌; 如果這個選項的值為500 , 那麼執行時間超過500微秒的指令就會被記錄到慢查詢日誌; 諸如此類。
選項slowlog-max-len用於確定伺服器最多保留多少條慢查詢日誌。伺服器使用先進先出的方式保存多個慢查詢日誌: 當伺服器儲存的慢查詢日誌數量等於slowlog-max-len選項的值時,伺服器在新增一條新的慢查詢日誌之前,會先將最舊的一則慢查詢日誌刪除。舉個例子, 如果伺服器slowlog-max-len的值為100,並且假設伺服器已經儲存了100條慢查詢日誌, 那麼如果伺服器打算添加一條新日誌的話,它就必須先刪除目前保存的最舊的那條日誌, 然後再新增日誌。
讓我們來看一個慢查詢日誌功能的例子,首先用CONFIG_SET指令將slowlog-log-slower-than選項的值設為0微秒, 這樣Redis伺服器執行的任何指令都會被記錄到慢查詢日誌中, 接著將slowlog-max-len選項的值設為5,讓伺服器最多只保存5個慢查詢日誌:
redis> CONFIG SET slowlog-log-slower-than 0 OK redis> CONFIG SET slowlog-max-len 5 OK
接著, 我們用客戶端發送幾個命令請求:
redis> SET msg "hello world"OK redis> SET number 10086 OK redis> SET database "Redis"OK
然後使用SLOWLOG GET命令查看伺服器所保存的慢查詢日誌:
redis> SLOWLOG GET 1) 1) (integer) 4 #日志的唯一标识符(uid); 2) (integer) 1378781447 #命令执行时的UNIX时间戳; 3) (integer) 13 #命令执行的时长,以微秒计算; 4) 1) "SET" #命令以及命令参数; 2) "database" 3) "Redis"2) 1) (integer) 3 2) (integer) 1378781439 3) (integer) 10 4) 1) "SET" 2) "number" 3) "10086"3) 1) (integer) 2 2) (integer) 1378781436 3) (integer) 18 4) 1) "SET" 2) "msg" 3) "hello world"4) 1) (integer) 1 2) (integer) 1378781425 3) (integer) 11 4) 1) "CONFIG" 2) "SET" 3) "slowlog-max-len" 4) "5"5) 1) (integer) 0 2) (integer) 1378781415 3) (integer) 53 4) 1) "CONFIG" 2) "SET" 3) "slowlog-log-slower-than" 4) "0"
如果這時再執行一條SLOWLOG GET 1命令,那麼我們將看到, 上一次執行的SLOWLOG GET指令已經被記錄到了慢查詢日誌中, 而最舊的、編號為0的慢查詢日誌已經被刪除,伺服器的慢查詢日誌數量仍然為5條:
redis> SLOWLOG GET 1 1) 1) (integer) 5 2) (integer) 1378781521 3) (integer) 61 4) 1) "SLOWLOG" 2) "GET"
日誌的唯一id只有在Redis伺服器重啟的時候才會重置,這樣可以避免對日誌的重複處理(例如你可能會想在每次發現新的慢查詢時發郵件通知你)。
使用指令SLOWLOG LEN可以查看目前日誌的數量。
請注意這個值和 slower-max-len的區別,它們一個是目前日誌的數量,一個是允許記錄的最大日誌的數量。
redis> SLOWLOG LEN (integer) 5
清空日誌
使用指令SLOWLOG RESET可以清空slow log 。
redis> SLOWLOG RESET OK
以上是Redis慢查詢日誌怎麼使用的詳細內容。更多資訊請關注PHP中文網其他相關文章!

Redis是现在最热门的key-value数据库,Redis的最大特点是key-value存储所带来的简单和高性能;相较于MongoDB和Redis,晚一年发布的ES可能知名度要低一些,ES的特点是搜索,ES是围绕搜索设计的。

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了关于redis的一些优势和特点,Redis 是一个开源的使用ANSI C语言编写、遵守 BSD 协议、支持网络、可基于内存、分布式存储数据库,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了Redis Cluster集群收缩主从节点的相关问题,包括了Cluster集群收缩概念、将6390主节点从集群中收缩、验证数据迁移过程是否导致数据异常等,希望对大家有帮助。

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了Redis实现排行榜及相同积分按时间排序,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,希望对大家有帮助。

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了关于原子操作中命令原子性的相关问题,包括了处理并发的方案、编程模型、多IO线程以及单命令的相关内容,下面一起看一下,希望对大家有帮助。

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了bitmap问题,Redis 为我们提供了位图这一数据结构,位图数据结构其实并不是一个全新的玩意,我们可以简单的认为就是个数组,只是里面的内容只能为0或1而已,希望对大家有帮助。

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了Redis实现排行榜及相同积分按时间排序,本文通过实例代码给大家介绍的非常详细,下面一起来看一下,希望对大家有帮助。

redis error就是redis数据库和其组合使用的部件出现错误,这个出现的错误有很多种,例如Redis被配置为保存数据库快照,但它不能持久化到硬盘,用来修改集合数据的命令不能用。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

Atom編輯器mac版下載
最受歡迎的的開源編輯器

Dreamweaver Mac版
視覺化網頁開發工具

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。