首頁 資料庫 Redis redis用在哪裡

redis用在哪裡

Jun 25, 2019 am 11:45 AM
redis

redis用在哪裡

1. 高並發快取/共享session:

    UserInfo getUserInfo (long id) {}

#    取:

    userRedisKey = "user:info:" id;

    value = redis.get(userRedisKey );

    if (value != null) {

userInfo = deserialize(value);

           return userInfo;

    }

#    儲存:

    }

#    儲存:

   InfoInfo = ***getoo);

    redis.setex(userRedisKey, 3600, serialize(userInfo));

    用string儲存序列化後的數據,不夠立體直觀,可以轉為hmset儲存為哈希結構,存取更直觀

 

2. 簡單分散式鎖定

    setnx只有在不存在時才設定成功,其餘只能等待。單線程

 

3. 計數器incr,因為是單線程,比cas等少了cpu消耗,性能更高

    long incrVideoCounter ( long id) {

          key = "video:playCount:" id;

          return redis.incr(key);

#4. 實現棧/隊列

    棧:       lpush lpop

    隊列:    lpush rpop 

 

5. 流量控制/限速

    phoneNum = "12345678999";

    key = "shortMsg:limit:"  phoneNum;

##   dis. key, 1, "EX 60", "NX");

    if (isExists != null || redis.incr(key) <= 5) {

           //透過

    } else {

          //不通過

    }

 

6. 消息隊列

    使用lpush brpop可實現阻塞佇列,生產者從列表左端lpush插入元素,多個消費者從右端brpop阻塞取得佇列尾部元素

 

#7. 每個使用者有自己的文章,現在要分頁展示文章清單

    hmset article:1 title xx context XXXX

##    hmset article:1 title xx context XXXX

    lpush user:1:articles srticle:1 articles:3

    articles = lrange user:1:articles 0 9

    for article in {articles}

          hgetall {article}

#          hgetall {article}

> #8. 追蹤按讚等

    讚: zincrby user:ranking:2016_03_15 mike 1

    取消: zrem user:ranking:2016_03_15 mike

取得讚  最多的10位使用者: zrevrangebyrank user:ranking:2016_03_15 0 9

    顯示使用者資訊與分數: hgetall user:info:tom /  zscore user:ranking:2016_03_15 mike /  zscore user:ranking:2016_03_15 mike /

9. bitmaps 計算大數據集合見的關係等 ## 

10. 排行榜

     mike上傳了一個影片並獲得了3個讚  zadd user:ranking:2016_03_15 mike 3

     又有人給了一個讚# 

11. 共同關注

     為使用者新增追蹤標籤  sadd user:1:tags tag1 tag2    user:1

     共同關注  sinter user:1:tags user:2:tags

     sinter/sunion/sdiff

 

12.發佈訂閱

     subscribe video:changes:     publish video:changeds "video1,video2"

   (video)

 

每種資料type對應了多種底層資料結構實作(object encoding),可以透過資料大小長度場景等切換,達到更高的效率

持久化RDB(子進程創建,二進位文件,恢復快,不夠實時)/AOF(appendonly。文字文件,即時寫入操作先aop_buffer,然後透過配置寫入磁碟間隔,寫入磁碟,達到一定大小合併)

批次hmget等操作要轉為hscan等漸進式遍歷方法,否則容易阻塞

緩衝:客戶端緩衝(輸入/輸出),複製積壓緩衝,aof緩衝

複製: 全量/增量 複製偏移量/複製積壓緩衝(寫入命令發送給從伺服器同時也維護一個先進先出的佇列,等於主服務還保存著最近傳播的命令)/ID

sentinal: 實現高可用,本身是特殊的redis節點,可以自己配置集群,透過心跳等機制監控redis資料集群,當某一節點出現故障不可用,可以及時發現並自動遷移

cluster: 分佈式集群,容錯選主等。將實體結點對應到16383個插槽實現動態性

更多Redis相關技術文章,請造訪Redis教學欄位進行學習!

以上是redis用在哪裡的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
4 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

redis集群模式怎麼搭建 redis集群模式怎麼搭建 Apr 10, 2025 pm 10:15 PM

Redis集群模式通過分片將Redis實例部署到多個服務器,提高可擴展性和可用性。搭建步驟如下:創建奇數個Redis實例,端口不同;創建3個sentinel實例,監控Redis實例並進行故障轉移;配置sentinel配置文件,添加監控Redis實例信息和故障轉移設置;配置Redis實例配置文件,啟用集群模式並指定集群信息文件路徑;創建nodes.conf文件,包含各Redis實例的信息;啟動集群,執行create命令創建集群並指定副本數量;登錄集群執行CLUSTER INFO命令驗證集群狀態;使

redis指令怎麼用 redis指令怎麼用 Apr 10, 2025 pm 08:45 PM

使用 Redis 指令需要以下步驟:打開 Redis 客戶端。輸入指令(動詞 鍵 值)。提供所需參數(因指令而異)。按 Enter 執行指令。 Redis 返迴響應,指示操作結果(通常為 OK 或 -ERR)。

redis底層怎麼實現 redis底層怎麼實現 Apr 10, 2025 pm 07:21 PM

Redis 使用哈希表存儲數據,支持字符串、列表、哈希表、集合和有序集合等數據結構。 Redis 通過快照 (RDB) 和追加只寫 (AOF) 機制持久化數據。 Redis 使用主從復制來提高數據可用性。 Redis 使用單線程事件循環處理連接和命令,保證數據原子性和一致性。 Redis 為鍵設置過期時間,並使用 lazy 刪除機制刪除過期鍵。

redis怎麼查看所有的key redis怎麼查看所有的key Apr 10, 2025 pm 07:15 PM

要查看 Redis 中的所有鍵,共有三種方法:使用 KEYS 命令返回所有匹配指定模式的鍵;使用 SCAN 命令迭代鍵並返回一組鍵;使用 INFO 命令獲取鍵的總數。

redis怎麼讀源碼 redis怎麼讀源碼 Apr 10, 2025 pm 08:27 PM

理解 Redis 源碼的最佳方法是逐步進行:熟悉 Redis 基礎知識。選擇一個特定的模塊或功能作為起點。從模塊或功能的入口點開始,逐行查看代碼。通過函數調用鏈查看代碼。熟悉 Redis 使用的底層數據結構。識別 Redis 使用的算法。

redis計數器怎麼實現 redis計數器怎麼實現 Apr 10, 2025 pm 10:21 PM

Redis計數器是一種使用Redis鍵值對存儲來實現計數操作的機制,包含以下步驟:創建計數器鍵、增加計數、減少計數、重置計數和獲取計數。 Redis計數器的優勢包括速度快、高並發、持久性和簡單易用。它可用於用戶訪問計數、實時指標跟踪、遊戲分數和排名以及訂單處理計數等場景。

redis怎麼啟動服務器 redis怎麼啟動服務器 Apr 10, 2025 pm 08:12 PM

啟動 Redis 服務器的步驟包括:根據操作系統安裝 Redis。通過 redis-server(Linux/macOS)或 redis-server.exe(Windows)啟動 Redis 服務。使用 redis-cli ping(Linux/macOS)或 redis-cli.exe ping(Windows)命令檢查服務狀態。使用 Redis 客戶端,如 redis-cli、Python 或 Node.js,訪問服務器。

redis怎麼使用鎖 redis怎麼使用鎖 Apr 10, 2025 pm 08:39 PM

使用Redis進行鎖操作需要通過SETNX命令獲取鎖,然後使用EXPIRE命令設置過期時間。具體步驟為:(1) 使用SETNX命令嘗試設置一個鍵值對;(2) 使用EXPIRE命令為鎖設置過期時間;(3) 當不再需要鎖時,使用DEL命令刪除該鎖。

See all articles