1、string(字符串)
它師最基本的類型,可以理解為Memcached一模一樣的類型,一個key對應一個value。
注意:一個鍵最大能存儲 512MB。
特性:可以包含任何數據,比如jpg圖片或者序列化的對象,一個鍵最大能存儲512M
2、Hash(哈希)
Redis hash 是一個鍵值(key=>value)對集合。
Redis hash 是一個 string 類型的 field 和 value 的映射表,hash 特別適合用於存儲對象。
注意:每個 hash 可以存儲 232 -1 鍵值對(40多億)。
特性:適合存儲對象,並且可以像數據庫中update一個屬性一樣只修改某一項屬性值(Memcached中需要取出整個字符串反序列化成對象修改完再序列化存回去)
3、list(列表)
Redis 列表是簡單的字符串列表,按照插入順序排序。你可以添加一個元素到列表的頭部(左邊)或者尾部(右邊)。
注意:列表最多可存儲 232 - 1 元素 (4294967295, 每個列表可存儲40多億)。
特性:增刪快,提供了操作某一段元素的API
4、set(集合)
Redis 的 Set 是 string 類型的無序集合。
集合是通過哈希表實現的,所以添加,刪除,查找的復雜度都是 O(1)。
注意:以上實例中 rabbitmq 添加了兩次,但根據集合內元素的唯一性,第二次插入的元素將被忽略。
集合中最大的成員數為 232 - 1(4294967295, 每個集合可存儲40多億個成員)。
特性:
1、添加、刪除,查找的復雜度都是O(1)
2、為集合提供了求交集、並集、差集等操作
5、sorted set:有序集合
Redis zset 和 set 一樣也是string類型元素的集合,且不允許重復的成員。
不同的是每個元素都會關聯一個double類型的分數。redis正是通過分數來為集合中的成員進行從小到大的排序。
zset的成員是唯一的,但分數(score)卻可以重復。
特性:數據插入集合時,已經進行天然排序
----------------------------------------------------------
注意:Redis支持多個數據庫,並且每個數據庫的數據是隔離的不能共享,並且基於單機才有,如果是集群就沒有數據庫的概念。
Redis是一個字典結構的存儲服務器,而實際上一個Redis實例提供了多個用來存儲數據的字典,客戶端可以指定將數據存儲在哪個字典中。這與我們熟知的在一個關系數據庫實例中可以創建多個數據庫類似,所以可以將其中的每個字典都理解成一個獨立的數據庫。