• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            牽著老婆滿街逛

            嚴以律己,寬以待人. 三思而后行.
            GMail/GTalk: yanglinbo#google.com;
            MSN/Email: tx7do#yahoo.com.cn;
            QQ: 3 0 3 3 9 6 9 2 0 .

            Redis作者談Redis應用場景

            轉載自:http://blog.nosqlfan.com/html/2235.html

            毫無疑問,Redis開創了一種新的數據存儲思路,使用Redis,我們不用在面對功能單調的數據庫時,把精力放在如何把大象放進冰箱這樣的問題上,而是利用Redis靈活多變的數據結構和數據操作,為不同的大象構建不同的冰箱。希望你喜歡這個比喻。

            下面是一篇新鮮出爐的文章,其作者是Redis作者@antirez,他描述了Redis比較適合的一些應用場景,NoSQLFan簡單列舉在這里,供大家一覽:

            1.取最新N個數據的操作

            比如典型的取你網站的最新文章,通過下面方式,我們可以將最新的5000條評論的ID放在Redis的List集合中,并將超出集合部分從數據庫獲取

            • 使用LPUSH latest.comments<ID>命令,向list集合中插入數據
            • 插入完成后再用LTRIM latest.comments 0 5000命令使其永遠只保存最近5000個ID
            • 然后我們在客戶端獲取某一頁評論時可以用下面的邏輯(偽代碼)
            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操作

            這個需求與上面需求的不同之處在于,前面操作以時間為權重,這個是以某個條件為權重,比如按頂的次數排序,這時候就需要我們的sorted set出馬了,將你要排序的值設置成sorted set的score,將具體的數據設置成相應的value,每次只需要執行一條ZADD命令即可。

            3.需要精準設定過期時間的應用

            比如你可以把上面說到的sorted set的score值設置成過期時間的時間戳,那么就可以簡單地通過過期時間排序,定時清除過期數據了,不僅是清除Redis中的過期數據,你完全可以把Redis里這個過期時間當成是對數據庫中數據的索引,用Redis來找出哪些數據需要過期刪除,然后再精準地從數據庫中刪除相應的記錄。

            4.計數器應用

            Redis的命令都是原子性的,你可以輕松地利用INCR,DECR命令來構建計數器系統。

            5.Uniq操作,獲取某段時間所有數據排重值

            這個使用Redis的set數據結構最合適了,只需要不斷地將數據往set中扔就行了,set意為集合,所以會自動排重。

            6.實時系統,反垃圾系統

            通過上面說到的set功能,你可以知道一個終端用戶是否進行了某個操作,可以找到其操作的集合并進行分析統計對比等。沒有做不到,只有想不到。

            7.Pub/Sub構建實時消息系統

            Redis的Pub/Sub系統可以構建實時的消息系統,比如很多用Pub/Sub構建的實時聊天系統的例子。

            8.構建隊列系統

            使用list可以構建隊列系統,使用sorted set甚至可以構建有優先級的隊列系統。

            9.緩存

            這個不必說了,性能優于Memcached,數據結構更多樣化。

            來源:antirez.com


            posted on 2014-06-15 12:22 楊粼波 閱讀(561) 評論(0)  編輯 收藏 引用

            国产成人精品久久综合| 久久精品国产精品亚洲精品| 国产精品久久久久久一区二区三区 | 国内精品伊人久久久影院| 亚洲国产另类久久久精品黑人| 亚洲AV日韩精品久久久久久久| 久久99中文字幕久久| 伊人 久久 精品| 婷婷久久综合九色综合98| 99久久做夜夜爱天天做精品| 久久香蕉国产线看观看乱码| 亚州日韩精品专区久久久| 狠狠88综合久久久久综合网| 久久这里都是精品| 日本久久久精品中文字幕| 无码人妻久久久一区二区三区| 久久人妻少妇嫩草AV无码蜜桃| 久久精品99久久香蕉国产色戒| 性做久久久久久久久老女人| 一级做a爰片久久毛片人呢| 亚洲精品无码成人片久久| 中文成人无码精品久久久不卡| 国产精品无码久久综合网| 久久久久久午夜成人影院| 久久精品国产免费观看三人同眠| 国产精品九九久久免费视频| 国内精品伊人久久久久AV影院| 亚洲午夜久久久影院伊人| 色综合合久久天天给综看| 国产亚洲色婷婷久久99精品91| 久久久久免费精品国产| 激情伊人五月天久久综合| 国产午夜精品久久久久免费视| 精品国产乱码久久久久软件 | 久久人人爽人人爽人人av东京热| 精品无码久久久久久久动漫| 亚洲国产精品久久久久| AAA级久久久精品无码区| 久久久WWW免费人成精品| 久久精品无码av| 久久亚洲中文字幕精品一区|