redis筆記

来源:http://www.cnblogs.com/killbug/archive/2017/09/13/7517895.html
-Advertisement-
Play Games

redis筆記 下載完redis,執行make命令。 然後啟動redis就進src文件夾,執行./redis-server就可以了。 再在文件夾下執行 ./redis-cli 就可以執行redis的命令了。 pipelining 一次請求發送多個命令,以提高性能。我們在使用redis時都是向它發送命 ...


redis筆記

下載完redis,執行make命令。 然後啟動redis就進src文件夾,執行./redis-server就可以了。   再在文件夾下執行 ./redis-cli 就可以執行redis的命令了。   pipelining  一次請求發送多個命令,以提高性能。我們在使用redis時都是向它發送命令,每次都是需要和redis建立tcp連接,然後發送命令信息,redis執行命令後,客戶端等待著redis的響應。這個我們當然知道,就像訪問db,IO開銷都是消耗資源的大頭,所以redis提供了pipelining功能讓它具有一次傳輸多個命令共同執行的能力。 官網解釋文檔:https://redis.io/topics/pipelining   expire  為key設置過期時間,在到期時key會被刪除,可以通過PERSIST命令將key轉變成永久不過期的key,RENAME命令是不改變過期時間的。 內部的實現機制是怎麼樣的呢?主動刪除和被動刪除,主動的就是當這個key在被get的時候檢查是否已過期,如果過期就刪除。被動的是自身會周期性的挑選出一些有需要過期的key,1秒10次進行以下操作: 1,隨機挑選出20個key 2,刪除這20個鐘已經過期的key 3,如果刪除的key超過25%就繼續第一步 如此以抽樣的方式假定了整個redis記憶體儲的需要刪除卻沒被刪除的key在所有有過期機制的key中維持在25%以下。從概率的角度來講最壞的結果也許會發生。哈哈。 官方解釋文檔:https://redis.io/commands/expire#expire-accuracy   Pub/Sub  這個功能實現了發佈訂閱,訂閱者是訂閱一個channel,發佈者向這個channel發送message。發佈者和訂閱者都可是多個。 訂閱者命令: 發佈者命令: 而且還支持對channel的匹配方式,用PSUBSCRIBE和PUNSUBSCRIBE命令。 PSUBSCRIBE test* 或PUNSUBSCRIBEtest* 如此我們發現,發佈者是匹配模式,而訂閱者是正常模式,或發佈者是正常模式,訂閱者是匹配模式,或兩個都是匹配模式。增大了靈活性。 訂閱者命令: 發佈者命令: 官網文檔:https://redis.io/topics/pubsub   Transactions  事務,MULTI命令開啟事務,EXEC命令提交事務,DISCARD命令取消事務。 如下操作: 事務中異常場景: 1,在執行MULTI之後EXEC之前,操作redis出現異常的時候,如果收到QUEUED,說明已經在執行列里了,如果返回error,則需要取消事務。 2,在執行EXEC中出現異常,比如命令本身有錯,那麼事務在執行過程中出錯命令之前的命令將不會會退,而是被提交的。這裡要有特別註意。 如下操作:   我們看見在執行INCR a 時出錯,因為a的value是字元串。但是前面set命令卻是提交的。 redis為什麼沒有回退操作呢,在官方文檔中有這樣的解釋: 1,它認為redis 命令出錯只是因為語法有問題,那麼在實際場景中應該在到生產環境前已經被測試到。 2,它還認為redis足夠快,所以有自信不需要什麼會退操作。   競爭場景,使用WATCH來保證互斥操作。WATCH的key會被監控,如果在提交前key內容被改動那麼事務會提交失敗。 官網文檔:https://redis.io/topics/transactions   Distributed locks with Redis 官方有文檔描述瞭如何實現一個他們認為可靠的分散式鎖,他們稱呼這種實現演算法為redlock。也提供了各個語言版本的實現列表,java的話它列舉的是Redisson:https://github.com/redisson/redisson 單個redis 主備場景,推薦的是放key來鎖,value是client的唯一標誌,在獲取到已經有值時判斷是否是自己client的value,類似可重入鎖概念。另外在放的key上加上過期時間,防止client掛掉而導致鎖不能被其他client獲得。問題是master放好key,在同步給slave前掛掉了,slave成為master,卻沒有這個鎖的內容。所以它描述了一個redlock,對應的是多個resid主節點的方式來組建起存儲鎖的結構,核心是在所有節點里一半以上都被獲得鎖才算活得鎖,隨之而來的要處理超時間和依次放鎖時間延遲的問題等等。   Partitioning (橫向擴展) 多個redis實例,連接起來提供給系統緩存服務,可以隨著數據量增加,進行增加redis實例來進行擴展。文檔中介紹了兩種分割redis實例的辦法,一種是在開始的時候規定死一個redis存的是那些key,還有一種是動態的計算key的hash,然後取模分配到redis中去。 而我們也不得不認識到這種橫向擴展帶來的問題是一些操作上的限制,比如多個操作事務時就無法保證,不同redis實例存儲的集合不能操作並集等操作了,雖然我們可以想其他辦法解決,這也算帶來更大的複雜度。 作者還建議在一開始的時候就考慮切分不同redis實例,可以先在一臺機子上創建很多實例,組建好集群,當需要擴大存儲空間的時候,將一些節點移入到另一個機子上即可,可以實現無停機遷移。不過現實開發中似乎也不需要這樣去做,在數據量不斷上升的過程中是有機會配置出更多的實例的,影響其實不大。 實現方式目前有三種: 1,Redis Cluster 官方實現的推薦方案 2,Twemproxy (Twitter的開源項目)類似代理。 3,客戶端一致性hash jedis上就實現了這個方案,就是在客戶端發起存儲數據時對key進行hash演算法固定放入對應redis實例中。早前的Sharded代碼分析:http://www.cnblogs.com/killbug/p/3227851.html   LRU(Least Recently Used) maxmemory 配置項可以控制redis最大可用的記憶體。當存儲的內容達到這個最大值時,可以配置不同的策略。 在這個策略配置中可以配置在新增存儲時返回錯誤,或者執行刪除一些key來空出空間給新增的內容。而後者刪除又有一些策略,比如先刪除不常用的,或者隨機刪除等等。 redis據說是沒有實現真正的LRU演算法,在實現中為了接近演算法,使用了抽樣多個key在這些key中選出最應該刪除的進行刪除。抽樣的數量可以配置。事實上,LRU演算法是要求最近使用的被嚴格保留的。而redis實現者認為嚴格實現的話有點消耗記憶體。 4.0實現了一個LFU( Least Frequently Used),LRU會帶來這樣一個問題:當在決策刪除key的時候,偏向保留剛剛訪問過的key,而如果這些key在很長一段時間都不被使用而只是在刪除決策之前剛剛被訪問了一下而被保留,是不夠科學的。而LFU則是把訪問頻繁的key保留,在緩存的世界里可能更加有用一些。 說起LRU,Caffeine開源項目,傳說使用現代化演算法達到了超高的命中率,號稱世界上最好的緩存庫實現。 文檔:https://redis.io/topics/lru-cache
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 按照格式輸出提交號 作者 時間 git log --pretty=format:"%h %an %cd" --date=iso 獲取所有遠程的tag和他的commit sha1 git ls-remote --tags origin | grep [0-9]$ 獲取從 開始時間 到 結束時間 之間的 ...
  • SourceTree比命令行更容易操作,能更直觀看到發生了什麼。但是沒有哪一家git圖形化軟體能完成git的所有操作,封裝後的使用也隱藏了git的一些細節,在圖形化工具出現一些非常罕見的情況時,還是需要使用命令行輔助。 克隆項目 Source URL 為git地址的URL,推薦使用SSH地址,因此在 ...
  • 簡介: 定義函數: def xx(): print("xxx") 執行函數 xx() 函數返回值: 上述中,return為返回值,返回給r。return想返回什麼就返回什麼,如果沒有寫返回值,就返回None,就是空。 函數的普通參數: 如果實參不是按照順序給形參值的情況:(在實參內指定就行了) 函數 ...
  • #set集合,無序不可重覆setjh={'ofgh','gegds','uutytr'}setjh.add('uuuuu')#添加單個元素setjh.remove('ofgh')#刪掉單個元素print(setjh)#字典 鍵和值 建不可重覆zidian={'cn':"chain",'cn':'ch ...
  • 如果想在程式中加入惡意代碼,裝飾器是不錯的選擇! 一來裝飾器函數一般在主程式外定義,不易被髮現; 二來裝飾器函數在主程式運行之前執行,可以在主程式運行之前,獲得系統分配的資源. ...
  • 安裝pdf擴展1. wget http://pecl.php.net/get/pdflib-4.1.2.tgz2. tar zxvf pdflib-4.1.2.tgz3. cd pdflib-4.1.2.tgz4. /opt/lampp/bin/phpize5. ./configure --with ...
  • 官方手冊地址:http://effbot.org/imagingbook/image.htm Image模塊 圖像模塊提供了一個具有相同名稱的類,用於表示一個PIL的圖像。該模塊還提供了許多功能,包括載入圖片文件函數和創建新的圖像函數。 模塊示例: 下麵的程式載入一個圖像,再旋轉45度,並使用一個外 ...
  • 簡單的BBS論壇 實現功能 git倉庫地址: https://github.com/uge3/BBS 1、整體參考“抽屜新熱榜” + “博客園” 2、實現不同論壇版塊 3、帖子列表展示 4、個人博客主頁 5、個人博客標簽、分類、時間 篩選 6、帖子評論數、點贊數展示 7、允許登錄用戶發貼、評論、點贊 ...
一周排行
    -Advertisement-
    Play Games
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...