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 10000rdbcompression
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-value512
#指定在超過一定的數量或最大的元素超過某一臨界值時,採用一種特殊的雜湊演算法。 -
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
記憶體管理的一種頁面置換演算法,對於在記憶體中但又不用的資料區塊(記憶體區塊)叫做LRU,作業系統會根據哪些資料屬於LRU而將其移除記憶體騰出空間來加載另外的數據。
- volatile-lru
設定逾時時間的資料中,刪除最不常用使用的資料
- #allkeys-lru
查詢所有的key中最不常使用的資料進行刪除,這是應用最廣泛的策略。
- volatile-random
在已設定了逾時的資料中隨機刪除
- allkeys-random
查詢所有的key,之後隨機刪除
- #volatile-ttl
查詢全部設定超時時間的數據,之後排序,將馬上要國企的數據進行刪除
- noeviction
如果設定為該屬性,則不會進行刪除操作,在記憶體溢出時報錯回傳
-
############################################### #####volatile-lfu### 從所有配置了逾時時間的鍵中刪除使用頻率最少的鍵###
allkeys-lfu 從所有鍵中刪除使用頻率最少的鍵
#三、自訂設定Redis
進入對應的安裝目錄/usr/local/redis
,修改redis.conf 設定檔。
作為初學者Redis一般需要修改下面三項:
- 將daemonize
no
修改為daemonizeyes
,即改為以守護程式啟動。 - 將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中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

Redis集群模式通過分片將Redis實例部署到多個服務器,提高可擴展性和可用性。搭建步驟如下:創建奇數個Redis實例,端口不同;創建3個sentinel實例,監控Redis實例並進行故障轉移;配置sentinel配置文件,添加監控Redis實例信息和故障轉移設置;配置Redis實例配置文件,啟用集群模式並指定集群信息文件路徑;創建nodes.conf文件,包含各Redis實例的信息;啟動集群,執行create命令創建集群並指定副本數量;登錄集群執行CLUSTER INFO命令驗證集群狀態;使

如何清空 Redis 數據:使用 FLUSHALL 命令清除所有鍵值。使用 FLUSHDB 命令清除當前選定數據庫的鍵值。使用 SELECT 切換數據庫,再使用 FLUSHDB 清除多個數據庫。使用 DEL 命令刪除特定鍵。使用 redis-cli 工具清空數據。

要從 Redis 讀取隊列,需要獲取隊列名稱、使用 LPOP 命令讀取元素,並處理空隊列。具體步驟如下:獲取隊列名稱:以 "queue:" 前綴命名,如 "queue:my-queue"。使用 LPOP 命令:從隊列頭部彈出元素並返回其值,如 LPOP queue:my-queue。處理空隊列:如果隊列為空,LPOP 返回 nil,可先檢查隊列是否存在再讀取元素。

在CentOS系統上,您可以通過修改Redis配置文件或使用Redis命令來限制Lua腳本的執行時間,從而防止惡意腳本佔用過多資源。方法一:修改Redis配置文件定位Redis配置文件:Redis配置文件通常位於/etc/redis/redis.conf。編輯配置文件:使用文本編輯器(例如vi或nano)打開配置文件:sudovi/etc/redis/redis.conf設置Lua腳本執行時間限制:在配置文件中添加或修改以下行,設置Lua腳本的最大執行時間(單位:毫秒)

使用 Redis 命令行工具 (redis-cli) 可通過以下步驟管理和操作 Redis:連接到服務器,指定地址和端口。使用命令名稱和參數向服務器發送命令。使用 HELP 命令查看特定命令的幫助信息。使用 QUIT 命令退出命令行工具。

Redis計數器是一種使用Redis鍵值對存儲來實現計數操作的機制,包含以下步驟:創建計數器鍵、增加計數、減少計數、重置計數和獲取計數。 Redis計數器的優勢包括速度快、高並發、持久性和簡單易用。它可用於用戶訪問計數、實時指標跟踪、遊戲分數和排名以及訂單處理計數等場景。

Redis數據過期策略有兩種:定期刪除:定期掃描刪除過期鍵,可通過 expired-time-cap-remove-count、expired-time-cap-remove-delay 參數設置。惰性刪除:僅在讀取或寫入鍵時檢查刪除過期鍵,可通過 lazyfree-lazy-eviction、lazyfree-lazy-expire、lazyfree-lazy-user-del 參數設置。

在Debian系統中,readdir系統調用用於讀取目錄內容。如果其性能表現不佳,可嘗試以下優化策略:精簡目錄文件數量:盡可能將大型目錄拆分成多個小型目錄,降低每次readdir調用處理的項目數量。啟用目錄內容緩存:構建緩存機制,定期或在目錄內容變更時更新緩存,減少對readdir的頻繁調用。內存緩存(如Memcached或Redis)或本地緩存(如文件或數據庫)均可考慮。採用高效數據結構:如果自行實現目錄遍歷,選擇更高效的數據結構(例如哈希表而非線性搜索)存儲和訪問目錄信
