1. <strong id="7actg"></strong>
    2. <table id="7actg"></table>

    3. <address id="7actg"></address>
      <address id="7actg"></address>
      1. <object id="7actg"><tt id="7actg"></tt></object>

        面試官:Redis為什么默認16個數(shù)據(jù)庫?

        共 1749字,需瀏覽 4分鐘

         ·

        2021-10-16 02:21

        你知道的越多,不知道的就越多,業(yè)余的像一棵小草!

        你來,我們一起精進!你不來,我和你的競爭對手一起精進!

        編輯:業(yè)余草

        toutiao.com/a6752317753866060299

        推薦:https://www.xttblog.com/?p=5281

        這兩天很心累,一個同學(xué),陸續(xù)從我這里借了幾萬元錢?,F(xiàn)在問他要,玩失蹤了。很疼心,哎,人好難。。。

        導(dǎo)讀:在實際項目中 Redis 常被應(yīng)用于做緩存,分布式鎖、消息隊列等。但是在搭建配置好 Redis 服務(wù)器后很多朋友應(yīng)該會發(fā)現(xiàn)和有這樣的疑問,為什么 Redis 默認建立了 16 個數(shù)據(jù)庫,如下圖所示。

        「一、16個數(shù)據(jù)庫的由來」

        Redis 是一個字典結(jié)構(gòu)的存儲服務(wù)器,一個 Redis 實例提供了多個用來存儲數(shù)據(jù)的字典,客戶端可以指定將數(shù)據(jù)存儲在哪個字典中。這與在一個關(guān)系數(shù)據(jù)庫實例中可以創(chuàng)建多個數(shù)據(jù)庫類似(如下圖所示),所以可以將其中的每個字典都理解成一個獨立的數(shù)據(jù)庫。

        以 MySQL 實例為例。

        Redis 默認支持 16 個數(shù)據(jù)庫,可以通過調(diào)整 Redis 的配置文件redis/redis.conf 中的 databases 來修改這一個值,設(shè)置完畢后重啟 Redis 便完成配置。

        客戶端與 Redis 建立連接后會默認選擇 0 號數(shù)據(jù)庫,不過可以隨時使用 SELECT 命令更換數(shù)據(jù)庫。

        在實際項目中則可以通過以 Redis 配置文件的形式指定數(shù)據(jù)庫,如下圖所示

        「二、正確理解 Redis 的“數(shù)據(jù)庫”概念」

        由于 Redis 不支持自定義數(shù)據(jù)庫的名字,所以每個數(shù)據(jù)庫都以編號命名。開發(fā)者則需要自己記錄存儲的數(shù)據(jù)與數(shù)據(jù)庫的對應(yīng)關(guān)系。另外 Redis 也不支持為每個數(shù)據(jù)庫設(shè)置不同的訪問密碼,所以一個客戶端要么可以訪問全部數(shù)據(jù)庫,要么全部數(shù)據(jù)庫都沒有權(quán)限訪問。但是,要正確地理解 Redis 的“數(shù)據(jù)庫”概念這里不得不提到一個命令:

        該命令可以清空實例下的所有數(shù)據(jù)庫數(shù)據(jù),這與我們所熟知的關(guān)系型數(shù)據(jù)庫所不同。關(guān)系型數(shù)據(jù)庫多個庫常用于存儲不同應(yīng)用程序的數(shù)據(jù) ,且沒有方式可以同時清空實例下的所有庫數(shù)據(jù)。所以對于 Redis 來說這些 db 更像是一種命名空間,且不適宜存儲不同應(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)存。

        「三、集群情況下是否支持一個實例多個db?」

        要注意以上所說的都是基于單體 Redis 的情況。而在集群的情況下不支持使用 select 命令來切換 db,因為 Redis 集群模式下只有一個 db0。再擴展一些集群與單機 Reids 的區(qū)別,感興趣的朋友可以去查閱相關(guān)的資料深入理解,這里就不做討論了。

        • key 批量操作支持有限:例如 mget、mset 必須在一個 slot
        • Key 事務(wù)和 Lua 支持有限:操作的 key 必須在一個節(jié)點
        • key 是數(shù)據(jù)分區(qū)的最小粒度:不支持 bigkey 分區(qū)
        • 不支持多個數(shù)據(jù)庫:集群模式下只有一個 db0
        • 復(fù)制只支持一層:不支持樹形復(fù)制結(jié)構(gòu)

        「四、總結(jié)」

        Redis 實例默認建立了 16 個 db,由于不支持自主進行數(shù)據(jù)庫命名所以以 dbX 的方式命名。默認數(shù)據(jù)庫數(shù)量可以修改配置文件的 database 值來設(shè)定。對于 db 正確的理解應(yīng)為“命名空間”,多個應(yīng)用程序不應(yīng)使用同一個 Redis 不同庫,而應(yīng)一個應(yīng)用程序?qū)?yīng)一個 Redis 實例,不同的數(shù)據(jù)庫可用于存儲不同環(huán)境的數(shù)據(jù)。最后要注意,Redis 集群下只有 db0,不支持多 db。


        以上,便是今天的分享,希望大家喜歡,覺得內(nèi)容不錯的,歡迎點擊「「在看」」支持,謝謝各位!

        瀏覽 57
        點贊
        評論
        收藏
        分享

        手機掃一掃分享

        分享
        舉報
        評論
        圖片
        表情
        推薦
        點贊
        評論
        收藏
        分享

        手機掃一掃分享

        分享
        舉報
        1. <strong id="7actg"></strong>
        2. <table id="7actg"></table>

        3. <address id="7actg"></address>
          <address id="7actg"></address>
          1. <object id="7actg"><tt id="7actg"></tt></object>
            www草草草 | 豆花欧美 日韩 视频 | 99精品一区二区 | 麻豆国产原创 | 大香蕉网视频 | 粉嫩小穴在线观看 | 国产福利第一页 | 揉我啊嗯~出水了 | 欧美日韩网站 | 大操视频网站 |