這篇文章主要講解了“redis數(shù)據(jù)庫的管理方式”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“Redis數(shù)據(jù)庫的管理方式”吧!
創(chuàng)新互聯(lián)堅持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:網(wǎng)站制作、成都網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時代的滎經(jīng)網(wǎng)站設(shè)計、移動媒體設(shè)計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
數(shù)據(jù)庫管理
在Redis中主要提供了dbsize、select、flushdb/flushall等命令,下面我們分別介紹這些命令的詳細(xì)使用。
1、切換數(shù)據(jù)庫
select index
我們知道在其它的關(guān)系型數(shù)據(jù)庫例如MySQL中也是支持有多個數(shù)據(jù)庫,并且基本上關(guān)系型數(shù)據(jù)庫都是以名字來判斷數(shù)據(jù)庫是否重復(fù)的。而在Redis中則不同,Redis是通過數(shù)字來判斷的數(shù)據(jù)庫是否重復(fù)的。在Redis中默認(rèn)的數(shù)據(jù)庫為0,而默認(rèn)最大的數(shù)據(jù)庫為16個。
select命令可以選擇切換的數(shù)據(jù)庫,因為Redis中默認(rèn)是從0開始的,所以默認(rèn)最大為15。如果超過這個范圍Redis則會提示報錯。并且在Redis中不同數(shù)據(jù)庫與數(shù)據(jù)庫之間,數(shù)據(jù)是不同步,也就是沒有任何關(guān)系,也就是如上圖所示。下面我們用更形象的圖來表示Redis不同數(shù)據(jù)庫之間的存儲。如下圖所示:
既然Redis中有多個數(shù)據(jù)庫的功能,那我們在日常開發(fā)中,是不是可以將生產(chǎn)中的數(shù)據(jù)存儲到指定的數(shù)據(jù)庫中,然后將測試環(huán)境中的數(shù)據(jù)存儲到另一個數(shù)據(jù)庫中呢?答案就是在技術(shù)上當(dāng)然是可以,但在業(yè)務(wù)上基本不會這么做,因為我們在平常使用關(guān)系型數(shù)據(jù)庫例如Mysql我們也不會將生產(chǎn)環(huán)境中的數(shù)據(jù)和測試環(huán)境中的數(shù)據(jù)存儲在同一個數(shù)據(jù)庫實例中,而基本都是將生產(chǎn)環(huán)境和測試環(huán)境分離。那么Redis也是一樣的。除此之外,在Redis以后在做分布式時,只允許使用0號數(shù)據(jù)庫,也就是說越高版本的Redis已經(jīng)越來越弱化這個功能了。只是為了兼容而沒有將多數(shù)據(jù)庫的功能去掉而已。下面我們分析一下,為什么Redis要弱化這個多數(shù)據(jù)庫的功能。
Redis是單線程的。我們已經(jīng)在以前的文章中多次介紹過了。所以即使我們按照業(yè)務(wù)把不同的數(shù)據(jù)存儲到不同的數(shù)據(jù)庫中,那在執(zhí)行相關(guān)命令時,因為單線程等原因,它們彼此之間還是會有影響的。
如我們在實際的開發(fā)中使用了多數(shù)據(jù)庫的功能,那么如果在某一個數(shù)據(jù)庫中出現(xiàn)相應(yīng)的問題,如慢查詢等。那么它會影響其它數(shù)據(jù)庫的相關(guān)性能,并且,我們還不好排查問題,因為相比一個數(shù)據(jù)庫來說,我們很難快速的定位出現(xiàn)的問題是在哪個數(shù)據(jù)庫中。
部分Redis客戶端工具并不支持,這種選擇多數(shù)據(jù)庫的功能。即使支持,也很有可能因為疏忽,而對不同的數(shù)據(jù)庫數(shù)據(jù)產(chǎn)生影響。
如我們在實際的開發(fā)中,如果想使用多個數(shù)據(jù)庫的功能時,可以向之前文章中介紹的那樣,部署多個實例,也就是不同的端口來實現(xiàn)多數(shù)據(jù)庫的功能。
2.flushdb/flushall
看名字我們應(yīng)該能猜到flushdb和flushall都是清空Redis數(shù)據(jù)庫的命令。它們的區(qū)別就是前者是清空當(dāng)前數(shù)據(jù)庫的中的數(shù)據(jù),而后者是清除所有數(shù)據(jù)庫中的數(shù)據(jù)。下面我們看具體的事例。
下面我們看一下flushdb/flushall的注意事項:
flushdb/flushall命令會一下清除Redis中當(dāng)前數(shù)據(jù)庫或者所有數(shù)據(jù)庫的內(nèi)容,如果我們操作失誤,很容易造成安全事故。在后續(xù)的文章中我們將介紹rename-command配置,rename-command配置則可以必免上述的問題,以及出現(xiàn)上述問題時的數(shù)據(jù)恢復(fù)。
如果當(dāng)前Redis中的數(shù)據(jù)量比較多時,flushdb/flushall命令可能會造成阻塞,所以要慎用。
感謝各位的閱讀,以上就是“Redis數(shù)據(jù)庫的管理方式”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對Redis數(shù)據(jù)庫的管理方式這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關(guān)知識點(diǎn)的文章,歡迎關(guān)注!