溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

如何使用key/value數(shù)據(jù)庫redis和TTSERVER

發(fā)布時間:2021-10-12 13:40:28 來源:億速云 閱讀:170 作者:小新 欄目:開發(fā)技術(shù)

小編給大家分享一下如何使用key/value數(shù)據(jù)庫redis和TTSERVER,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!

先說redis
redis是一個類似memcached的key/value存儲系統(tǒng),它支持存儲的value類型相對較多,包括string(字符串)、 list(鏈表)、set(集合)和zset(有序集合)。在此基礎(chǔ)上,redis支持各種不同方式的排序。與memcached一樣,為了保證效率,數(shù)據(jù)都是緩存在內(nèi)存中。區(qū)別的是redis會周期性的把更新的數(shù)據(jù)寫入磁盤或者把修改操作寫入追加的記錄文件(這點兒個人覺得redis比memcache 在數(shù)據(jù)保存上要安全一些),并且在此基礎(chǔ)上實現(xiàn)了master- slave(主從)同步。

redis的存取性能很高,SET操作每秒鐘 110000 次,GET操作每秒鐘 81000 次(速度很爽?。?。
Redis針對不同的存儲類型對象提供了不同的命令。
redis目前提供四種數(shù)據(jù)類型:string,list,set及zset(sorted set)。
string是最簡單的類型,你可以理解成與Memcached一模一個的類型,一個key對應(yīng)一個value,其上支持的操作與Memcached的操 作類似。但它的功能更豐富。

list是一個鏈表結(jié)構(gòu),主要功能是push、pop、獲取一個范圍的所有值等等。操作中key理解為鏈表的名字。
set是集合,和我們數(shù)學(xué)中的集合概念相似,對集合的操作有添加刪除元素,有對多個集合求交并差等操作。操作中key理解為集合的名字。

zset是set的一個升級版本,他在set的基礎(chǔ)上增加了一個順序?qū)傩?,這一屬性在添加修改元素的時候可以指定,每次指定后,zset會自動重新按新的 值調(diào)整順序。可以理解了有兩列的mysql表,一列存value,一列存順序。操作中key理解為zset的名字。

下面提供redis命令:
適合全體類型的命令
EXISTS key 判斷一個鍵是否存在;存在返回 1;否則返回0;
DEL key 刪除某個key,或是一系列key;DEL key1 key2 key3 key4
TYPE key 返回某個key元素的數(shù)據(jù)類型 ( none:不存在,string:字符,list,set,zset,hash)
KEYS pattern 返回匹配的key列表 (KEYS foo*:查找foo開頭的keys)
RANDOMKEY 隨機獲得一個已經(jīng)存在的key,如果當(dāng)前數(shù)據(jù)庫為空,則返回空字符串
RENAME oldname newname更改key的名字,新鍵如果存在將被覆蓋
RENAMENX oldname newname 更改key的名字,如果名字存在則更改失敗
DBSIZE返回當(dāng)前數(shù)據(jù)庫的key的總數(shù)
EXPIRE設(shè)置某個key的過期時間(秒),(EXPIRE bruce 1000:設(shè)置bruce這個key1000秒后系統(tǒng)自動刪除)注意:如果在還沒有過期的時候,對值進行了改變,那么那個值會被清除。
TTL查找某個key還有多長時間過期,返回時間秒
SELECT index 選擇數(shù)據(jù)庫
MOVE key dbindex 將指定鍵從當(dāng)前數(shù)據(jù)庫移到目標(biāo)數(shù)據(jù)庫 dbindex。成功返回 1;否則返回0(源數(shù)據(jù)庫不存在key或目標(biāo)數(shù)據(jù)庫已存在同名key);
FLUSHDB 清空當(dāng)前數(shù)據(jù)庫中的所有鍵
FLUSHALL 清空所有數(shù)據(jù)庫中的所有鍵

處理字符串的命令
SET key value 給一個鍵設(shè)置字符串值。SET keyname datalength data (SET bruce 10 paitoubing:保存key為burce,字符串長度為10的一個字符串paitoubing到數(shù)據(jù)庫),data最大不可超過1G。
GET key獲取某個key 的value值。如key不存在,則返回字符串“nil”;如key的值不為字符串類型,則返回一個錯誤。

GETSET key value可以理解成獲得的key的值然后SET這個值,更加方便的操作 (SET bruce 10 paitoubing,這個時候需要修改bruce變成1234567890并獲取這個以前的數(shù)據(jù)paitoubing,GETSET bruce 10 1234567890)
MGET key1 key2 … keyN 一次性返回多個鍵的值

SETNX key value SETNX與SET的區(qū)別是SET可以創(chuàng)建與更新key的value,而SETNX是如果key不存在,則創(chuàng)建key與value數(shù)據(jù)
MSET key1 value1 key2 value2 … keyN valueN 在一次原子操作下一次性設(shè)置多個鍵和值
MSETNX key1 value1 key2 value2 … keyN valueN 在一次原子操作下一次性設(shè)置多個鍵和值(目標(biāo)鍵不存在情況下,如果有一個以上的key已存在,則失?。?br/>INCR key 自增鍵值
INCRBY key integer 令鍵值自增指定數(shù)值
DECR key 自減鍵值
DECRBY key integer 令鍵值自減指定數(shù)值

處理 lists 的命令
RPUSH key value 從 List 尾部添加一個元素(如序列不存在,則先創(chuàng)建,如已存在同名Key而非序列,則返回錯誤)
LPUSH key value 從 List 頭部添加一個元素
LLEN key 返回一個 List 的長度
LRANGE key start end從自定的范圍內(nèi)返回序列的元素 (LRANGE testlist 0 2;返回序列testlist前0 1 2元素)
LTRIM key start end修剪某個范圍之外的數(shù)據(jù) (LTRIM testlist 0 2;保留0 1 2元素,其余的刪除)
LINDEX key index返回某個位置的序列值(LINDEX testlist 0;返回序列testlist位置為0的元素)
LSET key index value更新某個位置元素的值
LREM key count value 從 List 的頭部(count正數(shù))或尾部(count負數(shù))刪除一定數(shù)量(count)匹配value的元素,返回刪除的元素數(shù)量。
LPOP key 彈出 List 的第一個元素
RPOP key 彈出 List 的最后一個元素
RPOPLPUSH srckey dstkey 彈出 _srckey_ 中最后一個元素并將其壓入 _dstkey_頭部,key不存在或序列為空則返回“nil”

處理集合(sets)的命令(有索引無序序列)
SADD key member增加元素到SETS序列,如果元素(membe)不存在則添加成功 1,否則失敗 0;(SADD testlist 3 /n one)
SREM key member 刪除SETS序列的某個元素,如果元素不存在則失敗0,否則成功 1(SREM testlist 3 /N one)
SPOP key 從集合中隨機彈出一個成員
SMOVE srckey dstkey member 把一個SETS序列的某個元素 移動到 另外一個SETS序列 (SMOVE testlist test 3/n two;從序列testlist移動元素two到 test中,testlist中將不存在two元素)
SCARD key 統(tǒng)計某個SETS的序列的元素數(shù)量
SISMEMBER key member 獲知指定成員是否存在于集合中
SINTER key1 key2 … keyN 返回 key1, key2, …, keyN 中的交集
SINTERSTORE dstkey key1 key2 … keyN 將 key1, key2, …, keyN 中的交集存入 dstkey
SUNION key1 key2 … keyN 返回 key1, key2, …, keyN 的并集
SUNIONSTORE dstkey key1 key2 … keyN 將 key1, key2, …, keyN 的并集存入 dstkey
SDIFF key1 key2 … keyN 依據(jù) key2, …, keyN 求 key1 的差集。官方例子:
key1 = x,a,b,c
key2 = c
key3 = a,d
SDIFF key1,key2,key3 => x,b
SDIFFSTORE dstkey key1 key2 … keyN 依據(jù) key2, …, keyN 求 key1 的差集并存入 dstkey
SMEMBERS key 返回某個序列的所有元素
SRANDMEMBER key 隨機返回某個序列的元素

處理有序集合(sorted sets)的命令 (zsets)
ZADD key score member 添加指定成員到有序集合中,如果目標(biāo)存在則更新score(分值,排序用)
ZREM key member 從有序集合刪除指定成員
ZINCRBY key increment member 如果成員存在則將其增加_increment_,否則將設(shè)置一個score為_increment_的成員
ZRANGE key start end 返回升序排序后的指定范圍的成員
ZREVRANGE key start end 返回降序排序后的指定范圍的成員
ZRANGEBYSCORE key min max 返回所有符合score >= min和score <= max的成員 ZCARD key 返回有序集合的元素數(shù)量 ZSCORE key element 返回指定成員的SCORE值 ZREMRANGEBYSCORE key min max 刪除符合 score >= min 和 score <= max 條件的所有成員。

使用體會:
個人在覺得redis速度是不用說了(很快的),但是很消耗物理內(nèi)存,算是redis的一個弊端吧,redis適合數(shù)據(jù)量比較小速度更新快的類型的網(wǎng)站,比如社區(qū),不適合數(shù)據(jù)比較龐大的網(wǎng)站,比如論壇。以前用redis應(yīng)用的一個論壇帖子上,但是因為數(shù)據(jù)量太大,消耗物理內(nèi)存驚人而放棄了用 redis!

再說說TTSERVER
Tokyo Cabinet 是一個DBM的實現(xiàn)。這里的數(shù)據(jù)庫由一系列key-value對的記錄構(gòu)成。key和value都可以是任意長度的字節(jié)序列,既可以是二進制也可以是字符串。這里沒有數(shù)據(jù)類型和數(shù)據(jù)表的概念。當(dāng)做為Hash表數(shù)據(jù)庫使用時,每個key必須是不同的,因此無法存儲兩個key相同的值。提供了以下訪問方法:提供key,value參數(shù)來存儲,按 key刪除記錄,按key來讀取記錄,另外,遍歷key也被支持,雖然順序是任意的不能被保證。這些方法跟Unix標(biāo)準的DBM,例如GDBM,NDBM 等等是相同的,但是比它們的性能要好得多(因此可以替代它們) 當(dāng)按B+樹來存儲時,擁用相同key的記錄也能被存儲。像hash表一樣的讀取,存儲,刪除函數(shù)也都有提供。記錄按照用戶提供的比較函數(shù)來存儲。可以采用順序或倒序的游標(biāo)來讀取每一條記錄。依照這個原理,向前的字符串匹配搜索和整數(shù)區(qū)間搜索也實現(xiàn)了。另外,B+樹的事務(wù)也是可用的。對于定長的數(shù)組,記錄按自然數(shù)來標(biāo)記存儲。不能存儲key相同的兩條或更多記錄。另外,每條記錄的長度受到限 制。讀取方法和hash表的一樣。 Tokyo Cabinet是用C寫的,同時提供c,perl,ruby,java的API。Tokyo Cabinet在提供了POSIX和C99的平臺上都可用,它以GNU Lesser Public License協(xié)議發(fā)布。

tokyocabinet :一個key-value的DBM數(shù)據(jù)庫,但是沒有提供網(wǎng)絡(luò)接口,以下稱TC。
tokyotyrant :是為TC寫的網(wǎng)絡(luò)接口,他支持memcache協(xié)議,也可以通過HTTP操作,以下稱TT。

性能:
Tokyo Cabinet 是日本人 平林幹雄 開發(fā)的一款 DBM 數(shù)據(jù)庫,Tokyo Cabinet基于GNU Lesser General Public License協(xié)議發(fā)布,采用C語言開發(fā),它可以運行在任何支持C99和POSIX平臺上使用。相比一般的DBM數(shù)據(jù)庫有以下幾個特點:空間小,效率高,性能高,可靠性高,多種開發(fā)語言的支持(現(xiàn)已提供C,Perl,Ruby,Java,Lua的API),支持64位操作系統(tǒng)。該數(shù)據(jù)庫讀寫非???,哈希模式寫入100萬條數(shù)據(jù)只需0.643秒,讀取100萬條數(shù)據(jù)只需0.773秒,是 Berkeley DB 等 DBM 的幾倍。

Tokyo Tyrant 加上 Tokyo Cabinet,構(gòu)成了一款支持高并發(fā)的分布式持久存儲系統(tǒng),對任何原有Memcached客戶端來講,可以將Tokyo Tyrant看成是一個Memcached,但是,它的數(shù)據(jù)是可以持久存儲的。這一點,跟新浪的Memcachedb性質(zhì)一樣。

ttserver和memcache比較:
ttserver是數(shù)據(jù)庫,memcached是緩存。兩者都是保存&lt;key,value&gt;形式的數(shù)據(jù),通過key進行任何操作。ttserver可以將數(shù)據(jù)持久化保存,memcached全部是保存在內(nèi)存中,memcached會自動刪除過期數(shù)據(jù),最長不超過30天。memcached在和一些api配合時,能自動進行數(shù)據(jù)的出入序列化,讀取反序列化。ttserver有主從復(fù)制的功能,操作日志等,這完全是數(shù)據(jù)庫才有的東西。據(jù)說memcached正在對整體架構(gòu)做調(diào)整,到時候支持plugin機制.會把網(wǎng)絡(luò),事件處理,內(nèi)存存儲剝離開來.以后要做基于磁盤的key-value存儲就可以寫一個存儲引擎就成了。memcached的二次開發(fā)又步入一個小高潮。

看完了這篇文章,相信你對“如何使用key/value數(shù)據(jù)庫redis和TTSERVER”有了一定的了解,如果想了解更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI