
從上面的日志中可以了解到redis做快照存儲時,它會啟動一個線程去存儲快照,即便發生錯誤它也會每隔幾秒去重複的執行存儲快照的操作;其實上面的錯誤的原因是我們開啟了stop-writes-on-bgsave-error這個選項,是以為了避免這種錯誤發生,我們可以把stop-writes-on-bgsave-error這個選項設定為no,但是這樣設定以後我們還需要,通過監控來監控redis的日志,及時發現問題避免丢失資料;
上一篇部落格我們聊了下redis的INCLUDE、NETWORK、GENERAL配置段相關配置和說明,回顧請參考:https://www.cnblogs.com/qiuhom-1874/p/13383166.html;今天我們繼續來說redis的其他配置段相關配置和說明;
SNAPSHOTTING相關配置
save:該指令用于指定在多少時間内,至少發生了多少寫操作,就觸發一次快照;配置文法 save <seconds> <changes>;其中save是指令,seconds表示時間機關是秒,changes表示資料發生變化的次數(寫操作的次數);
示例:
提示:以上配置表示在900秒以内如果資料至少發生了一次變化就做一次快照,或者在300秒内資料發生了至少10次變化,就做一次快照或者在60秒内,資料發生了至少10000次變化就做一次快照;save可以多次配置,他們之間是或的關系,隻要滿足其中一條就會觸發快照操作;
stop-writes-on-bgsave-error:該指令用于指定是否開啟當做快照時發生錯誤停止伺服器寫入資料;預設是yes,表示開啟當做快照時發生錯誤而停止redis伺服器的寫入;在生産環境中不建議開啟,因為這個選項一旦開啟,當作快照時如果發生錯誤,會導緻整個redis伺服器寫操作不可用;
rdbcompression:該指令用于指定是否對快照檔案rdb做壓縮,預設是yes,開啟壓縮;
rdbchecksum:該指令用于指定是否對RDB檔案做校驗,預設是yes,開啟校驗rdb檔案功能;
dbfilename:該指令用于指定快照檔案的名稱,預設是dump.rdb
dir:該指令用于指定rdb存儲目錄路徑;預設編譯安裝,如果是用systemctl啟動,預設是/;如果是用redis-server +配置檔案路徑來啟動,預設就在目前執行指令的路徑下;這裡需要注意所在路徑的權限要對應啟動使用者有寫入權限,否則快照時會發生錯誤,提示沒有權限在指定路徑下建立快照檔案;如果是yum安裝預設是在/var/lib/redis/目錄下;
提示:以上配置表示配置redis如果在3秒鐘内至少有1次數就變化就觸發做一次快照;當在做快照時發生錯誤,停止redis的寫操作;啟用對快照檔案rdb做壓縮和校驗;快照檔案存儲到/var/lib/redis目錄下,名為dump_6379.rdb;
驗證:重新開機redis服務,用redis-cli連接配接,在其指令行插入資料,看看是否會在對應目錄下産生rdb檔案?
提示:在使用redis使用者啟動redis時,是能夠在對應目錄下生成快照檔案,說明我們配置的快照政策生效了;
驗證:重新開機redis,看看資料是否還在?
提示:可以看到我們重新開機了redis後,之前寫入的資料都還在,說明redis在啟動重新開機時會把rdb中的檔案資料加載到記憶體;
驗證:修改/var/lib/redis/目錄的屬主和屬組為root,然後往redis裡寫資料,看看會發生什麼?
提示:修改了/var/lib/redis/目錄的屬主/組為root後,再次連接配接redis讀取資料是可以正常讀取,但是寫入資料報錯,它告訴我們存儲快照時發生錯誤;
檢視日志
提示:從上面的日志中可以了解到redis做快照存儲時,它會啟動一個線程去存儲快照,即便發生錯誤它也會每隔幾秒去重複的執行存儲快照的操作;其實上面的錯誤的原因是我們開啟了stop-writes-on-bgsave-error這個選項,是以為了避免這種錯誤發生,我們可以把stop-writes-on-bgsave-error這個選項設定為no,但是這樣設定以後我們還需要,通過監控來監控redis的日志,及時發現問題避免丢失資料;
SECURITY相關配置
requirepass:該指令用于指定連接配接redis服務端所需的密碼;預設情況沒有啟用,生産中一定要設定密碼;
示例:設定連接配接redis密碼
提示:以上配置表示給redis設定密碼為admin123.com;
驗證:重新開機redis,不使用密碼是否能夠連接配接,操作redis?
提示:重新開機redis後,可以連接配接到redis,但是沒法操作redis;
提供密碼
提示:連接配接redis時可以使用-a來指定密碼;也可以連接配接到redis後使用auth 指令來指定密碼;
rename-command:該指令用于重寫那些高危指令,相當于給對應指令重命名;
示例:重寫flushall 為aaaa
提示:以上配置表示把flushall替換成aaaa;這意味着在用戶端執行FLUSHALL就不生效了;
驗證:重新開機redis,使用flushall看看會發生什麼?
提示:可以看到使用flushall指令就會報錯指令沒找到;使用aaaa就相當于使用flushall,這樣做的好處就是規避用戶端使用高危指令,造成不要的資料丢失;
LIMITS相關配置
maxclients:該指令用于指定最大用戶端連接配接數;預設是10000;
maxmemory:該指令用于指定最大記憶體,機關是位元組,這個選項一般不建議配置過大,過大極易觸發oom;
maxmemory-policy:該指令用于指定當最大内滿了以後,該怎麼清除裡面的資料;volatile-lru表示對有過期時長的資料進行LRU算法淘汰;allkeys-lru表示對所有鍵基于LRU算法淘汰;volatile-random對有過期時長的鍵進行随機淘汰;allkeys-random對所有鍵進行随機淘汰;noeviction不淘汰任何以存在的資料,如果有新資料來了,就錯誤提示;預設是noevicton
maxmemory-samples:該指令用于指定一次采樣key數量,預設是5個;基于采樣的5個鍵裡做LRU;
作者:Linux-1874
出處:https://www.cnblogs.com/qiuhom-1874/
本文版權歸作者和部落格園共有,歡迎轉載,但未經作者同意必須保留此段聲明,且在文章頁面明顯位置給出原文連接配接,否則保留追究法律責任的權利.