亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費注冊 查看新帖 |

Chinaunix

  平臺 論壇 博客 文庫
最近訪問板塊 發(fā)新帖
查看: 2302 | 回復: 0
打印 上一主題 下一主題

[Redis] Redis實戰(zhàn)《紅丸出品》1.3 初識Redis [復制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報告]
發(fā)表于 2012-06-02 23:23 |只看該作者 |倒序瀏覽
1.3 初識Redis
Redis是一個開源的使用ANSI C語言編寫、支持網(wǎng)絡、可基于內(nèi)存亦可持久化的日志型、Key-Value數(shù)據(jù)庫,并提供多種語言的API。從2010315日起,Redis的開發(fā)工作由VMware主持。
1.3.1 數(shù)據(jù)類型
作為Key-value型數(shù)據(jù)庫,Redis也提供了鍵(Key)和鍵值(Value)的映射關(guān)系。但是,除了常規(guī)的數(shù)值或字符串,Redis的鍵值還可以是以下形式之一:
l  Lists (列表)
l  Sets (集合)
l  Sorted sets (有序集合)
l  Hashes (哈希表)
鍵值的數(shù)據(jù)類型決定了該鍵值支持的操作。Redis支持諸如列表、集合或有序集合的交集、并集、查集等高級原子操作;同時,如果鍵值的類型是普通數(shù)字,Redis則提供自增等原子操作。
1.3.2 持久化
通常,Redis將數(shù)據(jù)存儲于內(nèi)存中,或被配置為使用虛擬內(nèi)存。通過兩種方式可以實現(xiàn)數(shù)據(jù)持久化:使用截圖的方式,將內(nèi)存中的數(shù)據(jù)不斷寫入磁盤;或使用類似MySQL的日志方式,記錄每次更新的日志。前者性能較高,但是可能會引起一定程度的數(shù)據(jù)丟失;后者相反。
1.3.3 主從同步
Redis支持將數(shù)據(jù)同步到多臺從庫上,這種特性對提高讀取性能非常有益。
1.3.4 性能
相比需要依賴磁盤記錄每個更新的數(shù)據(jù)庫,基于內(nèi)存的特性無疑給Redis帶來了非常優(yōu)秀的性能。讀寫操作之間有顯著的性能差異。
1.3.5 提供API的語言
l  C
l  C++
l  C#
l  Clojure
l  Common Lisp
l  Erlang
l  Haskell
l  Java
l  Javascript
l  Lua
l  Objective-C
l  Perl
l  PHP
l  Python
l  Ruby
l  Scala
l  Go
l  Tcl
1.3.6 適用場合
毫無疑問,Redis開創(chuàng)了一種新的數(shù)據(jù)存儲思路,使用Redis,我們不用在面對功能單調(diào)的數(shù)據(jù)庫時,把精力放在如何把大象放進冰箱這樣的問題上,而是利用Redis靈活多變的數(shù)據(jù)結(jié)構(gòu)和數(shù)據(jù)操作,為不同的大象構(gòu)建不同的冰箱。希望你喜歡這個比喻。
下面是Redis適用的一些場景:
1、取最新N個數(shù)據(jù)的操作
比如典型的取你網(wǎng)站的最新文章,通過下面方式,我們可以將最新的5000條評論的ID放在RedisList集合中,并將超出集合部分從數(shù)據(jù)庫獲取。
使用LPUSH latest.comments<ID>命令,向list集合中插入數(shù)據(jù)
插入完成后再用LTRIM latest.comments 0 5000命令使其永遠只保存最近5000ID
然后我們在客戶端獲取某一頁評論時可以用下面的邏輯
FUNCTION get_latest_comments(start,num_items):
    id_list = redis.lrange("latest.comments",start,start+num_items-1)
    IF id_list.length < num_items
        id_list = SQL_DB("SELECT ... ORDER BY time LIMIT ...")
    END
    RETURN id_list
END

如果你還有不同的篩選維度,比如某個分類的最新N條,那么你可以再建一個按此分類的List,只存ID的話,Redis是非常高效的。
2、排行榜應用,取TOP N操作
這個需求與上面需求的不同之處在于,前面操作以時間為權(quán)重,這個是以某個條件為權(quán)重,比如按頂?shù)拇螖?shù)排序,這時候就需要我們的sorted set出馬了,將你要排序的值設置成sorted setscore,將具體的數(shù)據(jù)設置成相應的value,每次只需要執(zhí)行一條ZADD命令即可。
3、需要精準設定過期時間的應用
比如你可以把上面說到的sorted setscore值設置成過期時間的時間戳,那么就可以簡單地通過過期時間排序,定時清除過期數(shù)據(jù)了,不僅是清除Redis中的過期數(shù)據(jù),你完全可以把Redis里這個過期時間當成是對數(shù)據(jù)庫中數(shù)據(jù)的索引,用Redis來找出哪些數(shù)據(jù)需要過期刪除,然后再精準地從數(shù)據(jù)庫中刪除相應的記錄。
4、計數(shù)器應用
Redis的命令都是原子性的,你可以輕松地利用INCR,DECR命令來構(gòu)建計數(shù)器系統(tǒng)。
5、Uniq操作,獲取某段時間所有數(shù)據(jù)排重值
這個使用Redisset數(shù)據(jù)結(jié)構(gòu)最合適了,只需要不斷地將數(shù)據(jù)往set中扔就行了,set意為集合,所以會自動排重。
6、實時系統(tǒng),反垃圾系統(tǒng)
通過上面說到的set功能,你可以知道一個終端用戶是否進行了某個操作,可以找到其操作的集合并進行分析統(tǒng)計對比等。沒有做不到,只有想不到。
7、Pub/Sub構(gòu)建實時消息系統(tǒng)
RedisPub/Sub系統(tǒng)可以構(gòu)建實時的消息系統(tǒng),比如很多用Pub/Sub構(gòu)建的實時聊天系統(tǒng)的例子。
8、構(gòu)建隊列系統(tǒng)
使用list可以構(gòu)建隊列系統(tǒng),使用sorted set甚至可以構(gòu)建有優(yōu)先級的隊列系統(tǒng)。
9、緩存
這個不必說了,性能優(yōu)于Memcached,數(shù)據(jù)結(jié)構(gòu)更多樣化。

-------------------------------------------------------------------
《MongoDB管理與開發(fā)精要》、《Redis實戰(zhàn)》作者
ChinaUnix.net專家博主 http://cdhongwan.blog.chinaunix.net
@CD紅丸                    http://weibo.com/u/2446082491


您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則 發(fā)表回復

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報專區(qū)
中國互聯(lián)網(wǎng)協(xié)會會員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP