redis集合對象的存儲
A. redis怎麼存儲list對象
方案一:直接使用List結構,List裡面存儲二進制的任務Bean信息,這樣做查詢全部任務很方便,查詢單條任務速度較慢,並且刪除和修改狀態很麻煩;方案二:直接使用Hash結構,Hash的key存儲任務ID,value存儲二進制的Bean信息,這樣做查詢所有任務、查詢單條任務以及刪除任務都很快,但是修改狀態也必須先取出數據再修改再插入!
B. redis怎麼存儲
redis是一個性能非常優秀的內存資料庫,通過key-value存儲系統。
和Memcached類似,它支持存儲的value類型相對更多,包括string(字元串)、list(鏈表)、set(集合)、zset(sorted set --有序集合)和hashs(哈希類型)。
這些數據類型都支持push/pop、add/remove及取交集並集和差集及更豐富的操作,而且這些操作都是原子性的。
與memcached一樣,為了保證效率,數據都是緩存在內存中。區別的是redis會周期性的把更新的數據寫入磁碟或者把修改操作寫入追加的記錄文件,並且在此基礎上實現了master-slave(主從)同步。
C. Redis有哪些數據類型
一、String | 字元串類型
Redis的字元串類型,可以存儲字元串、整數或浮點數,如果存儲的是整數或者浮點數,還能執行自增或自減操作。Reids的string類型是二進制的,可以包含任何數據,比如一個序列化的對象、一個圖片、位元組流等,不過存儲大小上限是512M。
Redis底層定義了自己的一種數據結構。
二、List | 列表類型
Redis的列表類型和許多編程語言中的列表類型類似,可以有序地存儲多個字元串,支持從列表的左端和右端推入或彈出元素,Redis列表的底層實現是壓縮列表,Redis內容自己實現的數據結構和雙端鏈表。
將一個或者多個value值插入列表的表頭。如果 key 不存在,會創建一個空列表並執行 LPUSH 操作。當 key
存在但不是列表類型時,返回一個錯誤。
三、set | 集合類型
Redis的集合以無序的方式存儲多個不同的元素,這里要注意的是無序和不同。除了對集合能快速執行添加、刪除、檢查一個元素是否在集合中之外,還可以對多個集合執行交集、並集和差集運算。
Redis的集合類型底層實現主要是通過一種叫做字典的數據結構。不過Redis為了追求極致的性能,會根據存儲的值是否是整數,選擇一種intset的數據結構。當滿足一定條件後,會切換成字典的實現。
四、hash | 散列表(哈希表)
Redis的hash類型其實就是一個縮減版的redis。它存儲的是鍵值對,將多個鍵值對存儲到一個redis鍵裡面。
hash類型的底層主要也是基於字典這種數據結構來實現的。
五、zset | 有序集合
有序集合相比較於集合,多個有序兩個字,我們知道set集合類型存儲的元素是無序的,那Redis有序集合是怎麼保證有序的?使用分值,有序集合里存儲這成員與分值之間的映射,並提供了分值處理命令,以及根據分值的大小有序地獲取成員或分值的命令。
Redis有序集合的實現使用了一種叫跳躍表的數據結構(簡稱跳錶,可自行查閱),同時也使用到了前面提到的壓縮列表。也是滿足一定條件的話,會自行轉換。
D. redis怎麼存儲類對象
Redis是Key-Value型內存資料庫,不能直接存儲對象,如果實體對象可以序列化,可以將序列化後的內容存入一個Value中。
E. redis的五種數據類型是什麼
如下:
一、string
string 是 redis 最基本的類型,你可以理解成與 Memcached 一模一樣的類型,一個 key 對應一個 value。
string 類型是二進制安全的。意思是 redis 的 string 可以包含任何數據。比如jpg圖片或者序列化的對象。
string 類型是 Redis 最基本的數據類型,string 類型的值最大能存儲 512MB。
命令: SET 和 GET 命令。
二、hash
Redis hash 是一個鍵值(key=>value)對集合。
Redis hash 是一個 string 類型的 field 和 value 的映射表,hash 特別適合用於存儲對象。
HMSET, HGET 命令,HMSET 設置了兩個 field=>value 對, HGET 獲取對應 field 對應的 value。
三、list
列表是簡單的字元串列表,按照插入順序排序。可以添加一個元素到列表的頭部(左邊)或者尾部(右邊)。
列表最多可存儲 232 - 1 元素 (4294967295,每個列表可存儲40多億)。
lpush 設置值,lrange取值。
四、set
redis的set是string的無序集合。集合通過哈希表實現。
添加一個string元素到key對應的set集合中,用 sadd命令。返回1表示成功,0表示在集合中已存在,返回錯誤表示key對應的set不存在。
查看用smembers 命令。
集合內元素的唯一性,第二次插入的元素將被忽略。
集合中最大的成員數為 232 - 1(4294967295, 每個集合可存儲40多億個成員)。
五、zset
redis的zset 和 set 一樣也是string類型元素的集合,且不允許重復的成員。
不同的是每個元素都會關聯一個double類型的分數。redis正是通過分數來為集合中的成員進行從小到大的排序。zset的成員是唯一的,但分數(score)卻可以重復。
添加元素到集合,元素在集合中存在則更新對應score:zadd key score member。
Redis數據模型:
Redis的外圍由一個鍵、值映射的字典構成。與其他非關系型資料庫主要不同在於:Redis中值的類型不僅限於字元串,還支持如下抽象數據類型:
1、字元串列表。
2、無序不重復的字元串集合。
3、有序不重復的字元串集合。
4、鍵、值都為字元串的哈希表。
值的類型決定了值本身支持的操作。Redis支持不同無序、有序的列表,無序、有序的集合間的交集、並集等高級伺服器端原子操作。
F. Redis存儲格式
redis目前提供四種數據類型:string,list,set及zset(sorted set)。
redis使用了兩種文件格式:全量數據和增量請求。全量數據格式是把內存中的數據寫入磁碟,便於下次讀取文件進行載入;增量請求文件則是把內存中的數據序列化為操作請求,用於讀取文件進行replay得到數據,序列化的操作包括SET、RPUSH、SADD、ZADD。redis的存儲分為內存存儲、磁碟存儲和log文件三部分,配置文件中有三個參數對其進行配置。save seconds updates,save配置,指出在多長時間內,有多少次更新操作,就將數據同步到數據文件。這個可以多個條件配合,比如默認配置文件中的設置,就設置了三個條件。appendonly yes/no ,appendonly配置,指出是否在每次更新操作後進行日誌記錄,如果不開啟,可能會在斷電時導致一段時間內的數據丟失。因為redis本身同步數據文件是按上面的save條件來同步的,所以有的數據會在一段時間內只存在於內存中。appendfsync no/always/everysec ,appendfsync配置,no表示等操作系統進行數據緩存同步到磁碟,always表示每次更新操作後手動調用fsync()將數據寫到磁碟,everysec表示每秒同步一次。
G. 如何在Redis通過StackExchange.Redis 存儲集合類型List
解決方案
如果你僅僅為了緩存存一批量的 List<Customer> 數據, 那麼自己封裝一個ListGet() 和 ListSet()方法吧。
我對比過使用 List 和 String 兩種類型存儲。
Redis 的List類型和 .NET領域還有所不同,實際上,它是一個雙向隊列,可以左右插入值。
所以如果是批量數據插入 那麼必須一個個插入, 代碼比較簡單如下:
//封裝的ListSet
publicvoidListSet<T>(stringkey,List<T>value)
{
.....
//下面的database是redis的資料庫對象.
foreach(varsingleinvalue)
{
vars=ConvertJson(single);//序列化
database.ListRightPush(key,s);//要一個個的插入
}
}
//封裝的ListGet
publicvoidListGet<T>(stringkey)
{
...
//ListRange返回的是一組字元串對象
//需要逐個反序列化成實體
varvList=database.ListRange(key);
List<T>result=newList<T>();
foreach(variteminvList)
{
varmodel=ConvertObj<T>(item);//反序列化
result.Add(model);
}
returnresult;
}
當然測試了一下性能,取20W條數據平均時間
H. redis 對象 鍵值 集合 組合怎麼存取
進入/usr/local/redis/bin/目錄下執行./redis-server /usr/local/redis/etc/redis.conf命令開啟Redis服務。
注意:開啟redis服務需要指定配置文件,如不指定配置文件則載入默認配置文件。
I. 怎樣在Redis通過StackExchange.Redis 存儲集合類型List
StackExchange 是由StackOverFlow出品, 是對Redis的.NET封裝,被越來越多的.NET開發者使用在項目中。
絕大部分原先使用ServiceStack的開發者逐漸都轉了過來,由於SS在其新版中不再開源,並對免費版本有所限制。
實際問題
那麼用.NET的開發者會發現,其根本沒有對List類型的存儲封裝,那麼要實現一個類似如下需求:
假如我有一個Customer的模型。
java">publicclassCustomer
{
publicstringFirstName{get;set;}
publicstringLastName{get;set;}
publicstringAddress1{get;set;}
publicstringCity{get;set;}
publicstringState{get;set;}
}
var customers = new List<Customer>();
怎樣將List<customer> customers 存入Redis中呢?
來龍去脈
是由於StackExchange.Redis是一個純客戶端的代理,他僅僅實現了Redis自由的功能,並不額外封裝其它功能。 也不具備像ORM那樣的自動類型匹配。
他僅僅存儲鍵值對 像string 或者
byte[]。所以你明白了吧,必須序列化存儲,用類似Json格式一樣。像用第三方NewtonSoft或者是Google公司流行的ProtocolBuffers
序列化格式的Protobuf-Net 也是不錯的選擇。
Redis支持存儲的類型有五種String ,Hash ,List ,Set ,和Sorted Set, 正如上面說的,這些存儲類型全部由字元串構成。
其中Set類型是沒有順序的,並且值必須唯一, List類型有順序且允許重復。
解決方案
如果你僅僅為了緩存存一批量的 List<Customer> 數據, 那麼自己封裝一個ListGet() 和 ListSet()方法吧。
我對比過使用 List 和 String 兩種類型存儲。
Redis 的List類型和 .NET領域還有所不同,實際上,它是一個雙向隊列,可以左右插入值。
所以如果是批量數據插入 那麼必須一個個插入, 代碼比較簡單如下:
//封裝的ListSet
publicvoidListSet<T>(stringkey,List<T>value)
{
.....
//下面的database是redis的資料庫對象.
foreach(varsingleinvalue)
{
vars=ConvertJson(single);//序列化
database.ListRightPush(key,s);//要一個個的插入
}
}
//封裝的ListGet
publicvoidListGet<T>(stringkey)
{
...
//ListRange返回的是一組字元串對象
//需要逐個反序列化成實體
varvList=database.ListRange(key);
List<T>result=newList<T>();
foreach(variteminvList)
{
varmodel=ConvertObj<T>(item);//反序列化
result.Add(model);
}
returnresult;
}
當然測試了一下性能,取20W條數據平均時間
J. Redis在實際項目怎麼把一個對象,和list集合存進去,用哪種數據類型
如果需要用到Redis存儲List對象,而list又不需要進行操作,可以按照MC的方式進行存儲,不過Jedis之類的客戶端沒有提供API,可以有兩種思路實現:
1. 分別序列化 elements ,然後 set 存儲
2. 序列化List對象,set存儲
這兩種方法都類似MC的 Object方法存儲,運用這種方式意味著放棄redis對List提供的操作方法。