Redis是一個(gè)開(kāi)源的使用ANSI C語(yǔ)言編寫(xiě)、支持網(wǎng)絡(luò)、可基于內(nèi)存亦可持久化的日志型、Key-Value數(shù)據(jù)庫(kù),并提供多種語(yǔ)言的API。從2010年3月15日起,Redis的開(kāi)發(fā)工作由VMware主持。從2013年5月開(kāi)始,Redis的開(kāi)發(fā)由Pivotal贊助。
Redis是一個(gè)強(qiáng)大的內(nèi)存數(shù)據(jù)結(jié)構(gòu)存儲(chǔ),包含數(shù)據(jù)庫(kù),緩存和消息代理等多種用途。大多數(shù)人經(jīng)常認(rèn)為它不過(guò)是一個(gè)簡(jiǎn)單的鍵值存儲(chǔ),但其實(shí)它有更多的能力。下面我將會(huì)總結(jié)一些Redis可以做的事情的真實(shí)例子。

首先是整頁(yè)緩存。如果你正在使用服務(wù)器端呈現(xiàn)的內(nèi)容,則不需要為每個(gè)單獨(dú)的請(qǐng)求重新渲染每個(gè)頁(yè)面。使用如Redis這樣的緩存,你可以緩存經(jīng)常請(qǐng)求的內(nèi)容,從而大大減少請(qǐng)求最多的頁(yè)面的延遲,并且大多數(shù)框架針對(duì)Redis緩存頁(yè)面都有hooks。
簡(jiǎn)單命令
/ Set the page that will last 1 minuteSET key "<html>...</html>" EX 60// Get the pageGET key
Redis令人耀眼的地方之一就是排行榜。由于Redis在內(nèi)存中,因此可以非常快速和高效地處理遞增和遞減。將此與每個(gè)請(qǐng)求運(yùn)行SQL查詢(xún)比較,性能收益巨大!這與Redis的排序集相結(jié)合意味著你可以以毫秒為單位抓取列表中評(píng)分最高的項(xiàng)目,而且實(shí)現(xiàn)起來(lái)非常容易。
簡(jiǎn)單命令
// Add an item to the sorted setZADD sortedSet 1 "one"http:// Get all items from the sorted setZRANGE sortedSet 0 -1// Get all items from the sorted set with their scoreZRANGE sortedSet 0 -1 WITHSCORES
我所見(jiàn)的Redis最常見(jiàn)的用途是會(huì)話存儲(chǔ)。與其他會(huì)話存儲(chǔ)(如Memcache)不同,Redis可以保留數(shù)據(jù),以便在緩存停止的情況下,在重新啟動(dòng)時(shí),所有數(shù)據(jù)仍然存在。即便不是需要嚴(yán)格持續(xù)的任務(wù),此功能仍可以為你的用戶(hù)省去大量的麻煩。沒(méi)有人會(huì)樂(lè)于見(jiàn)到他們的會(huì)話被無(wú)緣無(wú)故隨機(jī)刪掉。
簡(jiǎn)單命令
// Set session that will last 1 minuteSET randomHash "{userId}" EX 60// Get userIdGET randomHash使用Redis可以做的一個(gè)不太常見(jiàn),但非常有用的事情是排隊(duì)。無(wú)論是電子郵件隊(duì)列還是其他應(yīng)用程序使用的數(shù)據(jù),你都可以在Redis中創(chuàng)建一個(gè)高效的隊(duì)列。任何熟悉堆棧以及會(huì)push和pop項(xiàng)目的開(kāi)發(fā)人員都可以輕松自然地使用此功能。
簡(jiǎn)單命令
// Add a MessageHSET messages <id> <message>ZADD due <due_timestamp> <id>// Recieving MessageZRANGEBYSCORE due -inf <current_timestamp> LIMIT 0 1HGET messages <message_id>// Delete MessageZREM due <message_id>HDEL messages <message_id>
Redis在真實(shí)世界的最終用法即我將在這篇文章中提出的pub / sub。這是Redis內(nèi)置的最強(qiáng)大的功能之一;得到的可能是無(wú)限的。你可以創(chuàng)建一個(gè)實(shí)時(shí)聊天系統(tǒng),在社交網(wǎng)絡(luò)上觸發(fā)好友請(qǐng)求的通知等等。這個(gè)功能是Redis提供的最被低估的功能之一,但功能非常強(qiáng)大,而且使用簡(jiǎn)單。
簡(jiǎn)單命令
// Add a message to a channelPUBLISH channel message// Recieve messages from a channelSUBSCRIBE channel
結(jié)論
我希望你會(huì)喜歡這些Redis在真實(shí)世界的使用。雖然這篇文章只抓住了Redis能為你做的事情的表面,但是我希望你能從中獲得應(yīng)如何充分利用Redis的啟發(fā)。
新聞熱點(diǎn)
疑難解答
圖片精選