Redis服務之常用配置(二)

来源:https://www.cnblogs.com/qiuhom-1874/archive/2020/07/29/13394411.html
-Advertisement-
Play Games

從上面的日誌中可以瞭解到redis做快照存儲時,它會啟動一個線程去存儲快照,即便發生錯誤它也會每隔幾秒去重覆的執行存儲快照的操作;其實上面的錯誤的原因是我們開啟了stop-writes-on-bgsave-error這個選項,所以為了避免這種錯誤發生,我們可以把stop-writes-on-bgs... ...


  上一篇博客我們聊了下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;


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 本部分內容對應視頻鏈接。 熟悉我的朋友應該知道,我本科及碩士期間所學的專業都是機械相關,畢業兩年之後才從零開始自學轉行成為一名程式員。當時我寫了一篇文章,介紹我的轉行經歷,很多小伙伴因為我的這篇文章,備受鼓舞,給自己增加了很多信心,也靠這篇文章給自己加油打氣最終轉行成功。 我的文章能夠幫到那麼多人, ...
  • 在CentOS 7上將主機埠與容器埠映射時可能遇到無法訪問容器服務的問題,涉及到firewalld的配置。 ...
  • 系統環境: centos 7 git:gitee.com 當然隨便一個git服務端都行 jenkins: lts版本,部署在伺服器上,沒有通過部署在k8s集群中 harbor: offline版本,用來存儲docker鏡像 Kubernetes 集群為了方便快捷,使用了kubeadm方式搭建,是三台 ...
  • SRAM是可在任何CMOS工藝中“免費獲得”的存儲器。自CMOS誕生以來,SRAM一直是任何新CMOS工藝的開發和生產製造的技術驅動力。利用最新的所謂的“深度學習領域專用域結構”(DSA),每個晶元上的SRAM數量已達到數百兆位。這導致了兩個具體挑戰。接下來由專註於代理銷售SRAM、SDRAM、MR ...
  • 保證bios和網卡支持WOL喚醒,並關閉低功耗模式 此命令僅在Ubuntu20.04LTS上測試通過,其餘發行版同理,請自測 參考鏈接 https://www.techrepublic.com/article/how-to-enable-wake-on-lan-in-ubuntu-server-18 ...
  • [伺服器]SSL安裝證書教程 來自阿裡雲教程 Tomcat伺服器安裝SSL證書 安裝PFX格式證書 https://help.aliyun.com/document_detail/98576.html?spm=a2c4g.11186623.6.569.38e320c60poQbT 安裝JKS格式證書 ...
  • 你是否還在為 git pull/push 失敗而煩惱?本文提供的這個小工具幫你搞定不穩定的網路! ...
  • 最近在一次登錄伺服器時,系統提示多次登錄失敗:There were xxx failed login attemps since the last successful login. 作為小白的我第一次遇到,雖說沒什麼損失,也藉此也學習一下應對方法。為方便以後使用,在此做簡單的整理記錄。 SSH暴力 ...
一周排行
    -Advertisement-
    Play Games
  • 一:背景 準備開個系列來聊一下 PerfView 這款工具,熟悉我的朋友都知道我喜歡用 WinDbg,這東西雖然很牛,但也不是萬能的,也有一些場景他解決不了或者很難解決,這時候藉助一些其他的工具來輔助,是一個很不錯的主意。 很多朋友喜歡在項目中以記錄日誌的方式來監控項目的流轉情況,其實 CoreCL ...
  • 什麼是工業物聯網網關 工業物聯網網關是連接工業場景本地設備(如PLC、掃碼槍、機器人、數控機床等)與遠端業務系統(如SCADA系統、MES系統等)之間的硬體設備或軟體程式。終端設備和遠端業務系統之間的所有數據通信都通過工業物聯網網關來實現。 我們為什麼需要工業物聯網網關 因為從事汽車工業行業,在我們 ...
  • 在.NET Core的依賴註入框架中,服務註冊的信息將會被封裝成ServiceDescriptor對象,而這些對象都會存儲在IServiceCollection介面類型表示的集合中,另外,IServiceCollection介面類型預設使用的實現類型為ServiceCollection。這樣來看,實 ...
  • 如果業務邏輯比較簡單的話,一條主管道就夠了,確實用不到分支管道。不過當業務邏輯比較複雜的時候,有時候我們可能希望根據情況的不同使用特殊的一組中間件來處理 HttpContext。這種情況下如果只用一條管道,處理起來會非常麻煩和混亂。此時就可以使用 Map/MapWhen/UseWhen 建立一個分支 ...
  • .NET nanoFramework 安裝教程 準備材料​ esp32單片機(支持wifi藍牙) 安卓數據線(需要支持傳輸) 註意!請先安裝esp32驅動程式​ ESP32驅動鏈接 安裝 .NET nanoFramework固件快閃記憶體​ 安裝工具 dotnet tool install -g nano ...
  • Redis是大規模互聯網應用常用的記憶體高速緩存資料庫,它的讀寫速度非常快,據官方 Bench-mark的數據,它讀的速度能到11萬次/秒,寫的速度是8.1萬次/秒。 1. 認識Spring Cache 在很多應用場景中通常是獲取前後相同或更新不頻繁的數據,比如訪問產品信息數據、網頁數據。如果沒有使用 ...
  • 1、應用場景 1.1 kafka場景 ​ Kafka最初是由LinkedIn公司採用Scala語言開發,基於ZooKeeper,現在已經捐獻給了Apache基金會。目前Kafka已經定位為一個分散式流式處理平臺,它以 高吞吐、可持久化、可水平擴展、支持流處理等多種特性而被廣泛應用。 ​ Apache ...
  • Python帶我起飛——入門、進階、商業實戰_ 免費下載地址 內容簡介 · · · · · · 《Python帶我起飛——入門、進階、商業實戰》針對Python 3.5 以上版本,採用“理論+實踐”的形式編寫,通過大量的實例(共42 個),全面而深入地講解“Python 基礎語法”和“Python ...
  • 原文連接:https://www.zhoubotong.site/post/67.html Go 標準庫的net/url包提供的兩個函可以直接檢查URL合法性,不需要手動去正則匹配校驗。 下麵可以直接使用ParseRequestURI()函數解析URL,當然這個只會驗證url格式,至於功能變數名稱是否存在或 ...
  • 多商戶商城系統,也稱為B2B2C(BBC)平臺電商模式多商家商城系統。可以快速幫助企業搭建類似拼多多/京東/天貓/淘寶的綜合商城。 多商戶商城系統支持商家入駐加盟,同時滿足平臺自營、旗艦店等多種經營方式。平臺可以通過收取商家入駐費,訂單交易服務費,提現手續費,簡訊通道費等多手段方式,實現整體盈利。 ...