Redis为什么默认16个数据库,干什么用?
注意:Redis支持多個(gè)數(shù)據(jù)庫(kù),并且每個(gè)數(shù)據(jù)庫(kù)的數(shù)據(jù)是隔離的不能共享,并且基于單機(jī)才有,如果是集群就沒(méi)有數(shù)據(jù)庫(kù)的概念。
Redis是一個(gè)字典結(jié)構(gòu)的存儲(chǔ)服務(wù)器,而實(shí)際上一個(gè)Redis實(shí)例提供了多個(gè)用來(lái)存儲(chǔ)數(shù)據(jù)的字典,客戶(hù)端可以指定將數(shù)據(jù)存儲(chǔ)在哪個(gè)字典中。這與我們熟知的在一個(gè)關(guān)系數(shù)據(jù)庫(kù)實(shí)例中可以創(chuàng)建多個(gè)數(shù)據(jù)庫(kù)類(lèi)似,所以可以將其中的每個(gè)字典都理解成一個(gè)獨(dú)立的數(shù)據(jù)庫(kù)。
每個(gè)數(shù)據(jù)庫(kù)對(duì)外都是一個(gè)從0開(kāi)始的遞增數(shù)字命名,Redis默認(rèn)支持16個(gè)數(shù)據(jù)庫(kù)(可以通過(guò)配置文件支持更多,無(wú)上限),可以通過(guò)配置databases來(lái)修改這一數(shù)字??蛻?hù)端與Redis建立連接后會(huì)自動(dòng)選擇0號(hào)數(shù)據(jù)庫(kù),不過(guò)可以隨時(shí)使用SELECT命令更換數(shù)據(jù)庫(kù),如要選擇1號(hào)數(shù)據(jù)庫(kù):
redis> SELECT 1 OK redis [1] > GET foo (nil)然而這些以數(shù)字命名的數(shù)據(jù)庫(kù)又與我們理解的數(shù)據(jù)庫(kù)有所區(qū)別。首先Redis不支持自定義數(shù)據(jù)庫(kù)的名字,每個(gè)數(shù)據(jù)庫(kù)都以編號(hào)命名,開(kāi)發(fā)者必須自己記錄哪些數(shù)據(jù)庫(kù)存儲(chǔ)了哪些數(shù)據(jù)。另外Redis也不支持為每個(gè)數(shù)據(jù)庫(kù)設(shè)置不同的訪(fǎng)問(wèn)密碼,所以一個(gè)客戶(hù)端要么可以訪(fǎng)問(wèn)全部數(shù)據(jù)庫(kù),要么連一個(gè)數(shù)據(jù)庫(kù)也沒(méi)有權(quán)限訪(fǎng)問(wèn)。最重要的一點(diǎn)是多個(gè)數(shù)據(jù)庫(kù)之間并不是完全隔離的,比如FLUSHALL命令可以清空一個(gè)Redis實(shí)例中所有數(shù)據(jù)庫(kù)中的數(shù)據(jù)。綜上所述,這些數(shù)據(jù)庫(kù)更像是一種命名空間,而不適宜存儲(chǔ)不同應(yīng)用程序的數(shù)據(jù)。比如可以使用0號(hào)數(shù)據(jù)庫(kù)存儲(chǔ)某個(gè)應(yīng)用生產(chǎn)環(huán)境中的數(shù)據(jù),使用1號(hào)數(shù)據(jù)庫(kù)存儲(chǔ)測(cè)試環(huán)境中的數(shù)據(jù),但不適宜使用0號(hào)數(shù)據(jù)庫(kù)存儲(chǔ)A應(yīng)用的數(shù)據(jù)而使用1號(hào)數(shù)據(jù)庫(kù)B應(yīng)用的數(shù)據(jù),不同的應(yīng)用應(yīng)該使用不同的Redis實(shí)例存儲(chǔ)數(shù)據(jù)。由于Redis非常輕量級(jí),一個(gè)空Redis實(shí)例占用的內(nèi)在只有1M左右,所以不用擔(dān)心多個(gè)Redis實(shí)例會(huì)額外占用很多內(nèi)存。?
新人創(chuàng)作打卡挑戰(zhàn)賽發(fā)博客就能抽獎(jiǎng)!定制產(chǎn)品紅包拿不停!總結(jié)
以上是生活随笔為你收集整理的Redis为什么默认16个数据库,干什么用?的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: C/C++:Windows编程—Wind
- 下一篇: 数据库应用系统——引言