一、概述:
Redis在設計之初就被定義為長時間不間斷運行的服務進程,因此大多數系統配置參數都可以在不重新啟動進程的情況下立即生效。即便是將當前的持久化模式從AOF切換到RDB也無需重啟。
在Redis中,提供了一組和服務器管理相關的命令,其中就包含和參數設置有關的CONFIG SET/GET command。
二、相關命令列表:
命令原型 時間復雜度 命令描述 返回值 CONFIGGETparameter 主要用於讀取服務器的運行時參數,但是並不是所有的配置參數都可以通過該命令進行讀取。其中該命令的參數接受glob風格的模式匹配規則,因此如果參數中包含模式元字符,那麼所有匹配的參數都將以key/value方式被列出。如果參數是*,那麼該命令支持的所有參數都將被列出。最後需要指出的是,和redis.conf中不同的是,在命令中不能使用數量縮寫格式,如GB、KB等,只能使用表示字節數量的整數值。 CONFIG SETparameter value 該命令用於重新配置Redis服務器的運行時參數,在設置成功之後無需重啟便可生效。然而並非所有的參數都可以通過該命令進行動態設置,如果需要獲悉該命令支持哪些參數,可以查看CONFIG GET * 命令的執行結果。如果想在一個命令中設置多個同類型參數,如redis.conf配置文件中的save參數:save 900 1/save 300 10。在該命令中我們可以將多個key/value用雙引號括起,並用空格符隔開,如:config set save "900 1 300 10"。 OK表示設置成功,否則返回相關的錯誤信息。 CONFIG RESETSTAT O(1) Reset INFO命令給出的統計數字。 始終返回OK。 DBSIZE 返回當前打開的數據庫中Keys的數量。 Key的數量。 FLUSHALL 清空當前服務器管理的數據庫中的所有Keys,不僅限於當前打開的數據庫。 FLUSHDB 清空當前數據庫中的所有Keys。 INFO 獲取和服務器運行狀況相關的一些列統計數字。 SAVE 設置RDB持久化模式的保存策略。 SHUTDOWN 停止所有的客戶端,同時以阻塞的方式執行內存數據持久化。如果AOF模式被啟用,則將緩存中的數據flush到AOF文件。退出服務器。 SLAVEOFhost port 該命令用於修改SLAVE服務器的復制設置。如果一個Redis服務器已經處於SLAVE狀態,SLAVEOF NO ONE命令將關閉當前服務器的被復制狀態,與此同時將該服務器切換到MASTER狀態。該命令的參數將指定MASTER服務器的監聽IP和端口。還有一種情況是,當前服務器已經是另外一台MASTER的SLAVE了,在執行該命令後,當前服務器將終止和之前MASTER之間的復制關系,而將成為新MASTER的SLAVE,之前MASTER中的數據也將被清空,改為新MASTER中的數據。然而如果在當前SLAVE服務器上執行的是SLAVEOF NO ONE命令,那麼該服務器只是中斷與當前MASTER的復制關系,並升級為獨立的MASTER,其中的數據也不會被清空。 SLOWLOGsubcommand [argument] 該命令主要用於讀取執行時間較長的命令。其中執行時間的評判標准僅為命令本身的執行時間,並不包括網絡交互時間。和該命令相關的配置參數主要有兩個,第一個就是執行之間的阈值(以微秒為單位),即執行時間超過該值的命令都會被存入slowlog隊列,以供該命令讀取。第二個是slowlog隊列的長度,如果當前命令在存入之前,該隊列中的命令已經等於該參數,在命令進入之前,需要將隊列中最老的命令移出隊列。這樣可以保證該隊列所占用的內存總量保持在一個相對恆定的大小。由於slowlog隊列不會被持久化到磁盤,因此Redis在收集命令時不會對性能產生很大的影響。通常我們可以將參數"slowlog-log-slower-than"設置為0,以便收集所有命令的執行時間。該命令還包含以下幾個子命令: