redis-配置檔案詳解
阿新 • • 發佈:2021-07-29
如下:
====================================基本配置=============================== daemonize no #是否以後臺程序啟動 databases 16 #建立database的數量(預設選中的是database 0) save 900 1 #重新整理快照到硬碟中,必須滿足兩者要求才會觸發,即900秒之後至少1個關鍵字發生變化。 save 300 10 #必須是300秒之後至少10個關鍵字發生變化。 save60 10000 #必須是60秒之後至少10000個關鍵字發生變化。 stop-writes-on-bgsave-error yes #後臺儲存錯誤停止寫。 rdbcompression yes #使用LZF壓縮rdb檔案。 rdbchecksum yes #儲存和載入rdb檔案時校驗。 dbfilename dump.rdb #設定rdb檔名。 dir ./ #設定工作目錄,rdb檔案會寫入該目錄。====================================主從配置=============================== slaveof <masterip> <masterport> #設為某臺機器的從伺服器 masterauth <master-password> #連線主伺服器的密碼 slave-serve-stale-data yes #當主從斷開或正在複製中,從伺服器是否應答 slave-read-only yes #從伺服器只讀 repl-ping-slave-period10 #從ping主的時間間隔,秒為單位 repl-timeout 60 #主從超時時間(超時認為斷線了),要比period大 slave-priority 100 #如果master不能再正常工作,那麼會在多個slave中,選擇優先值最小的一個slave提升為master,優先值為0表示不能提升為master。 repl-disable-tcp-nodelay no #主端是否合併資料,大塊傳送給slave slave-priority 100 #從伺服器的優先順序,當主服掛了,會自動挑slave priority最小的為主服 ====================================安全==================================== requirepass foobared #需要密碼 rename-command CONFIG b840fc02d524045429941cc15f59e41cb7be6c52 #如果公共環境,可以重新命名部分敏感命令 如config ====================================限制==================================== maxclients 10000 #最大連線數 maxmemory <bytes> #最大使用記憶體 maxmemory-policy volatile-lru #記憶體到極限後的處理 volatile-lru -> LRU演算法刪除過期key allkeys-lru -> LRU演算法刪除key(不區分過不過期) volatile-random -> 隨機刪除過期key allkeys-random -> 隨機刪除key(不區分過不過期) volatile-ttl -> 刪除快過期的key noeviction -> 不刪除,返回錯誤資訊 #解釋 LRU ttl都是近似演算法,可以選N個,再比較最適宜T踢出的資料 maxmemory-samples 3 ====================================日誌模式================================ appendonly no #是否僅要日誌 appendfsync no # 系統緩衝,統一寫,速度快 appendfsync always # 系統不緩衝,直接寫,慢,丟失資料少 appendfsync everysec #折衷,每秒寫1次 no-appendfsync-on-rewrite no #為yes,則其他執行緒的資料放記憶體裡,合併寫入(速度快,容易丟失的多) auto-AOF-rewrite-percentage 100 #當前aof檔案是上次重寫是大N%時重寫 auto-AOF-rewrite-min-size 64mb #aof重寫至少要達到的大小 ====================================慢查詢================================== slowlog-log-slower-than 10000 #記錄響應時間大於10000微秒的慢查詢 slowlog-max-len 128 #最多記錄128條 ====================================服務端命令============================== time 返回時間戳+微秒 dbsize 返回key的數量 bgrewriteaof 重寫aof bgsave 後臺開啟子程序dump資料 save 阻塞程序dump資料 lastsave slaveof host port 做host port的從伺服器(資料清空,複製新主內容) slaveof no one 變成主伺服器(原資料不丟失,一般用於主服失敗後) flushdb 清空當前資料庫的所有資料 flushall 清空所有資料庫的所有資料(誤用了怎麼辦?) shutdown [save/nosave] 關閉伺服器,儲存資料,修改AOF(如果設定) slowlog get 獲取慢查詢日誌 slowlog len 獲取慢查詢日誌條數 slowlog reset 清空慢查詢 info [] config get 選項(支援*通配) config set 選項 值 config rewrite 把值寫到配置檔案 config restart 更新info命令的資訊 debug object key #除錯選項,看一個key的情況 debug segfault #模擬段錯誤,讓伺服器崩潰 object key (refcount|encoding|idletime) monitor #開啟控制檯,觀察命令(除錯用) client list #列出所有連線 client kill #殺死某個連線 CLIENT KILL 127.0.0.1:43501 client getname #獲取連線的名稱 預設nil client setname "名稱" #設定連線名稱,便於除錯 ====================================連線命令================================= auth 密碼 #密碼登陸(如果有密碼) ping #測試伺服器是否可用 echo "some content" #測試伺服器是否正常互動 select 0/1/2... #選擇資料庫 quit #退出連線
end!