當前位置:首頁 » 數據倉庫 » redis有幾個資料庫
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

redis有幾個資料庫

發布時間: 2023-01-16 03:11:24

① redis中怎麼查看資料庫的個數

命令:config get databases
默認16個

② redis centos 查詢有多少個資料庫

redis默認的資料庫是0~15一共16個資料庫,
可以通過配置再改多或改少資料庫。
可以使用select來選擇要查看的資料庫。

③ redis 一個資料庫能存多少數據

redis一個實例能存一個key或是value大小最大是512M。操作方法如下:

1、首先要安裝redis,開啟redis的服務。

④ redis一個庫里有幾張表

4張表,簡單動態字元串sds(Simple Dynamic String)雙端鏈表(LinkedList)字典(Map)跳躍表(SkipList)

⑤ Redis支持幾種數據類型

Redis支持五種數據類型:string(字元串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合)。

意思是 redis 的 string 可以包含任何數據。比如jpg圖片或者序列化的對象,string 類型的值最大能存儲 512MB。


Redis hash是一個 string 類型的 field 和 value 的映射表,hash 特別適合用於存儲對象。

Redis list是簡單的字元串列表,按照插入順序排序。可以添加一個元素到列表的頭部(左邊)或者尾部(右邊)。

Redis的Set是string類型的無序集合,集合是通過哈希表實現的,所以添加,刪除,查找的復雜度都是O(1)。

Redis zset 和 set 一樣也是string類型元素的集合,且不允許重復的成員,不同的是每個元素都會關聯一個double類型的分數。redis正是通過分數來為集合中的成員進行從小到大的排序。

⑥ Redis資料庫在哪些場景可以應用的到

redis開創了一種新的數據存儲思路,使用redis,我們不用在面對功能單調的資料庫時,把精力放在如何把大象放進冰箱這樣的問題上,而是利用redis靈活多變的數據結構和數據操作,為不同的大象構建不同的冰箱。
redis常用數據類型

redis最為常用的數據類型主要有以下五種:

string

hash

list

set

sorted set

在具體描述這幾種數據類型之前,我們先通過一張圖了解下redis內部內存管理中是如何描述這些不同數據類型的:

首先redis內部使用一個redisobject對象來表示所有的key和value,redisobject最主要的信息如上圖所示:type代表一
個value對象具體是何種數據類型,encoding是不同數據類型在redis內部的存儲方式,比如:type=string代表value存儲的是
一個普通字元串,那麼對應的encoding可以是raw或者是int,如果是int則代表實際redis內部是按數值型類存儲和表示這個字元串的,當然
前提是這個字元串本身可以用數值表示,比如:"123"
"456"這樣的字元串。

這里需要特殊說明一下vm欄位,只有打開了redis的虛擬內存功能,此欄位才會真正的分配內存,該功能默認是關閉狀態的,該功能會在後面具體描述。通過
上圖我們可以發現redis使用redisobject來表示所有的key/value數據是比較浪費內存的,當然這些內存管理成本的付出主要也是為了給
redis不同數據類型提供一個統一的管理介面,實際作者也提供了多種方法幫助我們盡量節省內存使用,我們隨後會具體討論。

下面我們先來逐一的分析下這五種數據類型的使用和內部實現方式:

string

常用命令:

set,get,decr,incr,mget 等。

應用場景:

string是最常用的一種數據類型,普通的key/value存儲都可以歸為此類,這里就不所做解釋了。

實現方式:

string在redis內部存儲默認就是一個字元串,被redisobject所引用,當遇到incr,decr等操作時會轉成數值型進行計算,此時redisobject的encoding欄位為int。

hash

常用命令:

hget,hset,hgetall 等。

應用場景:

我們簡單舉個實例來描述下hash的應用場景,比如我們要存儲一個用戶信息對象數據,包含以下信息:

用戶id為查找的key,存儲的value用戶對象包含姓名,年齡,生日等信息,如果用普通的key/value結構來存儲,主要有以下2種存儲方式:

第一種方式將用戶id作為查找key,把其他信息封裝成一個對象以序列化的方式存儲,這種方式的缺點是,增加了序列化/反序列化的開銷,並且在需要修改其中一項信息時,需要把整個對象取回,並且修改操作需要對並發進行保護,引入cas等復雜問題。

第二種方法是這個用戶信息對象有多少成員就存成多少個key-value對兒,用用戶id+對應屬性的名稱作為唯一標識來取得對應屬性的值,雖然省去了序列化開銷和並發問題,但是用戶id為重復存儲,如果存在大量這樣的數據,內存浪費還是非常可觀的。

那麼redis提供的hash很好的解決了這個問題,redis的hash實際是內部存儲的value為一個hashmap,並提供了直接存取這個map成員的介面,如下圖:

也就是說,key仍然是用戶id,
value是一個map,這個map的key是成員的屬性名,value是屬性值,這樣對數據的修改和存取都可以直接通過其內部map的key(redis里稱內部map的key為field),
也就是通過 key(用戶id) + field(屬性標簽)
就可以操作對應屬性數據了,既不需要重復存儲數據,也不會帶來序列化和並發修改控制的問題。很好的解決了問題。

這里同時需要注意,redis提供了介面(hgetall)可以直接取到全部的屬性數據,但是如果內部map的成員很多,那麼涉及到遍歷整個內部map的
操作,由於redis單線程模型的緣故,這個遍歷操作可能會比較耗時,而另其它客戶端的請求完全不響應,這點需要格外注意。

實現方式:

上面已經說到redis
hash對應value內部實際就是一個hashmap,實際這里會有2種不同實現,這個hash的成員比較少時redis為了節省內存會採用類似一維數組的方式來緊湊存儲,而不會採用真正的hashmap結構,對應的value
redisobject的encoding為zipmap,當成員數量增大時會自動轉成真正的hashmap,此時encoding為ht。

list

常用命令:

lpush,rpush,lpop,rpop,lrange等。

應用場景:

redis
list的應用場景非常多,也是redis最重要的數據結構之一,比如twitter的關注列表,粉絲列表等都可以用redis的list結構來實現,比較好理解,這里不再重復。

實現方式:

redis
list的實現為一個雙向鏈表,即可以支持反向查找和遍歷,更方便操作,不過帶來了部分額外的內存開銷,redis內部的很多實現,包括發送緩沖隊列等也都是用的這個數據結構。

set

常用命令:

sadd,spop,smembers,sunion 等。

應用場景:

redis
set對外提供的功能與list類似是一個列表的功能,特殊之處在於set是可以自動排重的,當你需要存儲一個列表數據,又不希望出現重復數據時,set是一個很好的選擇,並且set提供了判斷某個成員是否在一個set集合內的重要介面,這個也是list所不能提供的。

實現方式:

set 的內部實現是一個
value永遠為null的hashmap,實際就是通過計算hash的方式來快速排重的,這也是set能提供判斷一個成員是否在集合內的原因。

sorted set

常用命令:

zadd,zrange,zrem,zcard等

使用場景:

redis sorted set的使用場景與set類似,區別是set不是自動有序的,而sorted
set可以通過用戶額外提供一個優先順序(score)的參數來為成員排序,並且是插入有序的,即自動排序。當你需要一個有序的並且不重復的集合列表,那麼可以選擇sorted
set數據結構,比如twitter 的public

⑦ redis資料庫有哪些特點

性能極高–Redis讀的速度是11W次/s,寫的速度是81K次/s
支持數據的持久化,可以將內存中的數據保存在磁碟中,重啟的時候可以再次載入進行使用。
豐富的數據類型,Redis不僅僅支持簡單的key-value類型的數據,同時還提供Strings,Lists,Hashes,Sets及Ordered
Sets等數據結構的存儲。
支持數據的備份,即master-slave模式的數據備份。

⑧ redis 集群 可以有幾個db

1、redis 中的每一個資料庫,都由一個 redisDb 的結構存儲。其中,redisDb.id 存儲著 redis 資料庫以整數表示的號碼。redisDb.dict 存儲著該庫所有的鍵值對數據。redisDb.expires 保存著每一個鍵的過期時間。
2、當redis 伺服器初始化時,會預先分配 16 個資料庫(該數量可以通過配置文件配置),所有資料庫保存到結構 redisServer 的一個成員 redisServer.db 數組中。當我們選擇資料庫 select number 時,程序直接通過 redisServer.db[number] 來切換資料庫。有時候當程序需要知道自己是在哪個資料庫時,直接讀取 redisDb.id 即可。

⑨ redis 有資料庫表的概念嗎

redis就是kv存儲,沒有資料庫表的概念,你寫的東西一定要設置時限,或者寫好文檔,如果你走了,後期沒人維護,非常浪費資源。還有就是redis是存內存的,非常快速但是昂貴,建議你用redis存儲時先算一下數據量,看看你內存能不能裝下,需要幾台機器,幾台備份機,伺服器一旦重啟數據全無,使用時小心,望採納~