首頁  >  文章  >  資料庫  >  Redis設定檔redis.conf超詳細的解析

Redis設定檔redis.conf超詳細的解析

coldplay.xixi
coldplay.xixi轉載
2021-02-22 09:46:254969瀏覽

Redis設定檔redis.conf超詳細的解析

推薦(免費):redis教學

文章目錄

  • 一、常用的三十條配置
  • 二、Redis的記憶體淘汰策略
    • 2.1 為資料設定逾時時間
    • 2.2 採用LRU演算法動態將不使用的資料刪除
  • #三、自訂設定Redis

Linux下做開發要牢記:軟體預設安裝在/opt下,對於出廠預設設定的設定檔永遠不要去直接改動,正確的做法是備份一份後再操作

Redis的設定檔位於Redis安裝目錄下,檔案名稱為reids.conf,以下介紹常用的三十個配置,文章附帶英譯版redis.conf文件。

一、常用的三十條配置


前十條配置

  • daemonize no
    Redis預設不是以守護程式的方式執行,可以修改為yes啟用守護程式。

  • pidfile /var/run/redis/pid
    當Redis以守護程式方式執行時,Redis預設會把pid寫入/var/run/redis.pid文件,可以透過pidfile指定路徑。

  • port 6379
    # 指定Redis的監聽埠。

  • bind 127.0.0.1
    # Redis綁定的主機位址。

  • timeout 300
    設定當客戶端閒置多久後關閉連接,如果為0表示關閉該功能。

  • loglevel verbose
    # 指定日誌記錄級別,Redis共支援四個等級:debug、verbose(預設)、notice、 warning。

  • logfile stdout
    # 日誌記錄方式,預設為標準輸出,如果配置Redis為守護進程,而這裡的日誌記錄方式為標準輸出,則日誌會傳送給/dev/null

  • #databases 16
    設定資料庫的數量,預設數量為0,可以使用select <dbid>指令在連線上指定資料庫id。

  • save <seconds> <changes>
    指定多長時間內,有多少次更新操作,就將資料同步到資料文件,可以多個條件配合。 Redis配置文件中提供了3個條件:
    save 900 1; save 300 10 ;save 60 10000

  • rdbcompression yes
    指定儲存至本機資料庫時是否壓縮數據,預設為yes,Redis採用LZF(壓縮演算法)壓縮,如果為了節省cpu時間,可以關閉該選項,但是會導致資料庫檔案變的巨大。


中間十條設定

  • #dbfilename dump.rdb
    指定本機資料庫檔案名,預設值為dump.rdb

  • #dir ./
    指定本機資料庫存放目錄

  • slaveof <masterip><masterport>
    # 社會當本機為slav服務時,設定master服務的IP位址及端口,在Redis啟動時,會自動從master進行資料同步

  • #masterauth <master-password>
    ## 當master服務設定了密碼保護時,slav服務連線master的密碼。

  • requirepass foobared
    # 設定Redis的連線密碼,如果設定了連線密碼,則客戶端在連線Redis時需要透過AUTH<password>指令提供密碼,預設是關閉的。

  • maxclients 128
    # 設定同一時間最大客戶端連線數,預設無限制,Redis可以同時開啟的客戶端連接數為Redis進程可以開啟的最大檔案描述符數。如果設定maxclients 0,表示不做限制,當客戶端連線數到達限制時,Redis會關閉新的連線並向客戶端傳回max number of clients reached錯誤訊息。

  • maxmemory <bytes>
    指定Redis最大記憶體限制,Redis在啟動時會把資料載入到記憶體中,達到最大記憶體後,Redis會先嘗試清除已到期或即將到期的Key,當此方法處理後,仍然到達最大記憶體設置,將無法進行寫入操作,但仍可進行讀取操作。 Redis新的vm機制,會把Key存放內存,value存放在swap區。

  • appendonly no
    # 指定是否在某次更新操作後進行日誌記錄,Redis在預設情況下是一部的把資料寫入磁碟,如果不開啟,可能會在斷電時導致一段時間內的資料遺失。

  • appendfilename appendonly.aof
    # 指定更新日誌檔名,預設為appendonly.aof。

  • appendsync everysec
    指定更新日誌條件,共有三個可選項:
    ①no:表示等作業系統進行資料快取同步到磁碟(快)、
    ②always:表示每次更新作業系統後手動呼叫fsync()將資料寫入磁碟(慢、安全)、
    ③everysec:表示美妙同步一次(效率折中,為預設值)

最後十個

  • vm-enable no
    指定是否啟用虛擬記憶體機制,預設值為no,VM機制將資料分頁存放,由Redis將存取量較少的頁即冷資料swap到磁碟上,存取多的頁面由磁碟自動換出到內存中。
  • vm-swap-file /tmp/redis.swap
    虛擬記憶體檔案路徑,預設值為/tmp/redis.swap,不可多個Redis實例共享。
  • vm-max-memory 0
    將所有大於vm-max-memory的資料存入虛擬記憶體,無論vm-max-memory設定多小,所有索引資料都是記憶體儲存的(Redis的索引資料就是keys),也就是說,當vm-max-memory設定為0的時候,其實是所有value都存在於磁碟。預設值為0
  • vm-page-size 32
    Redis swap檔案分成了很多的page,一個物件可以儲存在多個page上面,但一個page上不能被多個對象共享,vm-page-size是要根據儲存的資料大小來設定的,如果儲存很多小對象,page大小最好設定為32或64bytes;如果儲存很大大對象,則可以使用較大的page,如果不確定,就使用預設值。
  • vm-pages 134217728
    設定swap檔案中的page數量,由於頁表(一種表示頁面空閒或使用的bitmap)是放在記憶體中的,在磁碟上每8個pages將消耗1byte的記憶體。
  • vm-max-threads 4
    設定存取swap檔案的執行緒數,不要超過機器的核數,如果設定為0,那麼所有對swap檔案的操作都是串列的,可能會造成比較長時間的延遲。預設值為4。
  • glueoutputbuf yes
    設定在向客戶端應答時,是否把較小的套件合併為一個套件發送,預設為開啟。
  • hash-max-zipmap-entries 64/hash-max-zipmap-value 512
    #指定在超過一定的數量或最大的元素超過某一臨界值時,採用一種特殊的雜湊演算法。
  • activerehashing yes
    指定是否啟動重設哈希,預設為開啟。
  • include /path/to/local.conf
    指定包含其它的設定文件,可以在同一台主機上多個Redis實例之間使用同一份配置文件,而同時各個實例又擁有自己的特定配置文件。

二、Redis的記憶體淘汰策略

Redis作為優秀的快取中間件,時常會儲存大量的數據,即使採用了叢集部署來動態擴容,也應該即時的清理內存,維護系統效能。

2.1 為資料設定逾時時間

  • expire key time(以秒為單位)                             
  • #setex(String Key, int seconds, String value)  字串獨有的方式
  • ##除了字串本身獨有設定過期時間的方法外,其他方法都需要依賴expire方法來設定時間。
如果沒有設定時間,那麼快取就是永不過期。

如果設定了過期時間,之後又想讓快取永不過期,使用
persist key

#2.2 採用LRU演算法動態將不使用的資料刪除

記憶體管理的一種頁面置換演算法,對於在記憶體中但又不用的資料區塊(記憶體區塊)叫做LRU,作業系統會根據哪些資料屬於LRU而將其移除記憶體騰出空間來加載另外的數據。

  1. volatile-lru

         設定逾時時間的資料中,刪除最不常用使用的資料

  2. #allkeys-lru

         查詢所有的key中最不常使用的資料進行刪除,這是應用最廣泛的策略。

  3. volatile-random

       在已設定了逾時的資料中隨機刪除

  4. allkeys-random

       查詢所有的key,之後隨機刪除

  5. #volatile-ttl

          查詢全部設定超時時間的數據,之後排序,將馬上要國企的數據進行刪除

  6. noeviction

          如果設定為該屬性,則不會進行刪除操作,在記憶體溢出時報錯回傳

  7. ############################################### #####volatile-lfu###      從所有配置了逾時時間的鍵中刪除使用頻率最少的鍵###
  8. allkeys-lfu      從所有鍵中刪除使用頻率最少的鍵

#三、自訂設定Redis

進入對應的安裝目錄/usr/local/redis,修改redis.conf 設定檔。

作為初學者Redis一般需要修改下面三項:

  • daemonize no 修改為daemonize yes,即改為以守護程式啟動。
  • bind 127.0.01 註解掉,即改為允許除本機外的機器存取Redis服務。
  • 使用requirepass 設定密碼,即確保服務安全/在極少數情況下不設定密碼無法進行遠端存取。

Redis採用的是單一行程多執行緒的模式。當redis.conf中選項daemonize設定成yes時,代表開啟守護程式模式。在該模式下,redis會在背景執行,並將程序pid號寫入至redis.conf選項pidfile設定的檔案中,此時redis將一直執行,除非手動kill該程序。但當daemonize選項設定成no時,目前介面將進入redis的命令列介面,exit強制退出或關閉連線工具(putty,xshell等)都會導致redis進程退出。服務端開發的應用程式大多是採用後台運行的模式。

更多相關學習:redis

以上是Redis設定檔redis.conf超詳細的解析的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:csdn.net。如有侵權,請聯絡admin@php.cn刪除