maxmemory: 指定 Redis 最大內(nèi)存限制
Redis 在啟動時會把數(shù)據(jù)加載到內(nèi)存中,達到最大內(nèi)存后,Redis 會先嘗試清除已到期或即將到期的 Key,當此方法處理 后,仍然到達最大內(nèi)存設(shè)置,將無法再進行寫入操作,但仍然可以進行讀取操作。Redis 新的 vm 機制,會把 Key 存放內(nèi)存,Value 會存放在 swap 區(qū)
Redis支持多個數(shù)據(jù)庫,并且每個數(shù)據(jù)庫的數(shù)據(jù)是隔離的不能共享,并且基于單機才有,如果是集群就沒有數(shù)據(jù)庫的概念。
Redis是一個字典結(jié)構(gòu)的存儲服務(wù)器,而實際上一個Redis實例提供了多個用來存儲數(shù)據(jù)的字典,客戶端可以指定將數(shù)據(jù)存儲在哪個字典中。這與我們熟知的在一個關(guān)系數(shù)據(jù)庫實例中可以創(chuàng)建多個數(shù)據(jù)庫類似,所以可以將其中的每個字典都理解成一個獨立的數(shù)據(jù)庫。
每個數(shù)據(jù)庫對外都是一個從0開始的遞增數(shù)字命名,Redis默認支持16個數(shù)據(jù)庫(可以通過配置文件支持更多,無上限),可以通過配置databases來修改這一數(shù)字。客戶端與Redis建立連接后會自動選擇0號數(shù)據(jù)庫,不過可以隨時使用SELECT命令更換數(shù)據(jù)庫,如要選擇1號數(shù)據(jù)庫
redis> SELECT 1 OK redis [1] > GET foo (nil)
然而這些以數(shù)字命名的數(shù)據(jù)庫又與我們理解的數(shù)據(jù)庫有所區(qū)別。
首先Redis不支持自定義數(shù)據(jù)庫的名字,每個數(shù)據(jù)庫都以編號命名,開發(fā)者必須自己記錄哪些數(shù)據(jù)庫存儲了哪些數(shù)據(jù)。
另外Redis也不支持為每個數(shù)據(jù)庫設(shè)置不同的訪問密碼,所以一個客戶端要么可以訪問全部數(shù)據(jù)庫,要么連一個數(shù)據(jù)庫也沒有權(quán)限訪問。
最重要的一點是多個數(shù)據(jù)庫之間并不是完全隔離的,比如FLUSHALL命令可以清空一個Redis實例中所有數(shù)據(jù)庫中的數(shù)據(jù)。綜上所述,這些數(shù)據(jù)庫更像是一種命名空間,而不適宜存儲不同應(yīng)用程序的數(shù)據(jù)。比如可以使用0號數(shù)據(jù)庫存儲某個應(yīng)用生產(chǎn)環(huán)境中的數(shù)據(jù),使用1號數(shù)據(jù)庫存儲測試環(huán)境中的數(shù)據(jù),但不適宜使用0號數(shù)據(jù)庫存儲A應(yīng)用的數(shù)據(jù)而使用1號數(shù)據(jù)庫B應(yīng)用的數(shù)據(jù),不同的應(yīng)用應(yīng)該使用不同的Redis實例存儲數(shù)據(jù)。由于Redis非常輕量級,一個空Redis實例占用的內(nèi)存只有1M左右,所以不用擔心多個Redis實例會額外占用很多內(nèi)存。