Redis運維和開發學習筆記(1) Redis簡介

文章目錄

  • Redis的特性
    • 速度快
    • 持久化
    • 多種數據結構
    • 主從復制
    • 高可用和分布式
  • 典型的應用場景
  • Redis啟動和可執行文件
    • Redis可執行文件說明
    • 啟動方式
    • 驗證redis
    • redis常用配置
  • redis數據結構和內部編碼
  • Redis是單線程,不會同時執行兩條命令
  • 哈希
  • 慢查詢
    • pipeline

Redis的特性

速度快

性能:10w ops(每秒10w次讀寫)

  • Redis 使用內存(寄存器>一級緩存>二級緩存>內存>本地磁盤>遠程磁盤)

持久化

特點:斷電不丟失數據

  • Redis將數據保存在內存,將更改數據異步保存在磁盤

多種數據結構

BitMap
GEO:地理位置定位
HyperLogLog:粗略的唯一計數

主從復制

高可用和分布式

  • Redis-Sentinel高可用
  • Redis-Cluster分布式

典型的應用場景

  • 緩存系統
    • 一個用戶訪問一個APP Server —> 緩存 —> Storage
  • 計數器
    • 視頻播放,點擊次數進行計數
  • 消息隊列系統
  • 排行榜
  • 實時系統

Redis啟動和可執行文件

Redis可執行文件說明

redis-serverRedis服務器
redis-cli RedisRedis命令行客戶端
redis-check-aofAOF文件修復工具
redis-check-dumpRDB文件檢查工具
redis-sentinel SentinelSentinel服務器

啟動方式

redis-server --port 6379(默認端口)
redis-server configPath
redis-cli -h (ip) -p (port)

驗證redis

ps -ef | grep redis
netstat -antpl | grep redis
redis -cli -h (ip) -p (port) ping

redis常用配置

daemonize默認no(不以守護進程啟動)
port6379
logfileRedis系統日志
dirRedis工作目錄

redis數據結構和內部編碼

在這里插入圖片描述

Redis是單線程,不會同時執行兩條命令

  • 為什么redis的單線程很快
    • 純內存–主要原因
    • 非阻塞IO(epoll多路復用)
    • 單線程避免了線程切換和靜態消耗
  • 一次只運行一條命令
  • 不使用慢命令(keys,flushall,flushdb,slow lua script, mutil/exec, operate big value(collection)
  • 不是單線程
    • fysnc file descriptor

哈希

慢查詢

  • 客戶端請求的生命周期

    • 發送命令
    • 排隊
    • 執行命令(慢查詢發生的時間)
    • 返回結構
  • 兩個配置

    • slowlog-max-len
    1. 先進先出的隊列
    2. 固定長度
    3. 保存在內存
    • slowlog-log-slower-than
      1. 慢查詢閾值
      2. =0, 記錄所有命令
    • 配置方案
      • config get slowlog-max-len = 128
      • config get slowlog-log-slower-than = 10000
      • 動態配置
      • config set slowlog-max-len = 128
      • config set slowlog-log-slower-than = 10000
  • 三個命令

    • slowlog get [n]: 獲取慢查詢隊列
    • slowlog len: 獲取慢查詢隊列長度
    • slowlog reset: 清空慢查詢隊列
  • 運維經驗

    • slowlog-max-len通常為1ms
    • slowlog-log-slower-than通常1000
    • 理解命令的生命周期
    • 定期持久化慢查詢日志(方便后期查詢歷史)

pipeline

  • 什么是流水線?
    • 一次網絡攜帶多條命令。
    • redis的命令式微妙級別
    • pipeline每次條數要控制(網絡)
      光速=3*108米/秒=30000公里/秒距離=1300公里
      光纖傳輸速度≈光速的2/3
      一次命令傳輸時間=(1300*2)/(300000*2/3)=13毫秒
      執行一條命令幾微妙,執行一條網絡要13毫秒。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/382398.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/382398.shtml
英文地址,請注明出處:http://en.pswp.cn/news/382398.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Effective C++學習第二天

1:確保對象被使用前已先被初始化,讀取未初始化的值會造成不明確的行為,可能導致程序終止運行或者其他不可預期的現象;在C中,當你使用C part of C(C中C語言部分的內容)且初始化可能導致運行期成本&#xff0…

Redis運維和開發學習筆記(3)redis搭建集群

Redis運維和開發學習筆記(3)redis搭建集群 文章目錄Redis運維和開發學習筆記(3)redis搭建集群Redis集群搭建Redis集群搭建 cp /etc/redis.d/redistest_7001.conf /etc/redis.d/redistest_XXXX.conf :%s/7001/xxxx/g 配置文件內容:cluster-enabled yes ############…

Effective C++學習第三天

1:為多態基類聲明virtual析構函數當我們創建一個base class指針指向新生成的derived class時,當刪除基類指針時,如果base class是一個non-virtual析構函數時,實際執行的結果通常是derived class中的base成分被銷毀,der…

linux創建指定大小的文件

一、生成文件大小和實際占空間大小一樣的文件 dd if/dev/zero ofname.file bs1M count1 文件名稱name.file bs1M表示每一次讀寫1M數據,count50表示讀寫 50次,這樣就指定了生成文件的大小為50M。 二、生成文件大小固定,但實際不占空間命令 …

Effective C++學習第四天

條款11:在operator中處理自我賦值的現象雖然我們在平時可能不會出現顯示自我賦值的現象,當加入指針或者引用時,可能會出現不同的指針或引用指向同一對象(對象的不同別名),這時候我們就得考慮對象是否是同一…

Effective C++學習第五天

條款14:在資源管理類中小心copy行為當我們深入理解“資源取得時機是初始化時機(RAII)”概念,并以此作為“資源管理類”的核心時,我們可能會遇到將RAII對象復制的情況,一般有兩種情況處理這個現象&#xff1…

Redis運維和開發學習筆記(2) redis持久化

Redis運維和開發學習筆記(2) redis持久化 文章目錄Redis運維和開發學習筆記(2) redis持久化持久化持久化方式一:RDB觸發~~的三種~~方式1. save命令2. bgsave配置觸發機制RDB 總結持久化方式二:AOFAOF的三種策略三種策略的優缺點AOF重寫機制持久化 redis將所有數據保存在內存中&…

Effective C++學習第六天

條款18:讓接口更容易被正確使用,不易被誤用設計接口的原則:正確性、高效性、封裝性、維護性、延展性以及協議的一致性;設計原則:1)導入新類型來預防很多客戶端的錯誤,多使用系統類型&#xff08…

Redis運維和開發學習筆記(4) Redis參數意義

Redis運維和開發學習筆記(4) Redis參數意義 文章目錄Redis運維和開發學習筆記(4) Redis參數意義參數意義參數意義 Client連接 問題 id567800790 addr10.18.17.217:37310 fd1572 name age2039114 idle2034860 flagsN db0 sub0 psub0 multi-1 qbuf0 qbuf-free0 obl0 oll0 omem0 …

Effective C++學習第七天

條款23:寧以non-memeber、non-friend替換member函數non-member/non-friend可以給對象帶來更大的封裝性,從兩個方面來考慮:1)考慮封裝,越多東西被封裝,它們就越不可見,就越少人看到它&#xff0c…

Redis運維和開發學習筆記(5) 主從復制和sentinel哨兵模式

Redis運維和開發學習筆記(5) 主從復制和sentinel哨兵模式 主從復制 將主節點的數據改變同步給從節點 作用 備份數據讀寫分離 存在的問題: 手動干預切主等操作主節點的寫能力受到單機限制主節點的存儲能力受到單機限制 主從模式的故障恢復 當主節點發生故障時&am…

Effective C++學習第八天

條款26:盡可能延后變量定義式的出現時間當你定義了一個變量,如果在使用變量之前出現異常,那么你得承受一次構造成本和析構成本,而且你沒有使用該變量;本條款給出的建議是延遲變量的定義,直到非得使用該變量…

Redis運維和開發學習筆記(6) 監控Redis工作狀態-info命令

Redis運維和開發學習筆記(6) 監控Redis工作狀態-info命令 文章目錄Redis運維和開發學習筆記(6) 監控Redis工作狀態-info命令info serverinfo clientinfo memoryinfo persistenceinfo statsinfo commandstatsinfo cpuinfo clusterinfo keyspaceinfo server Redis服務器相關的通用…

Effective C++學習第九天

條款32:確定你的public繼承塑模出is-a模型class D(derived)以public形式繼承class B(base),則每一個類型為D的對象同時也是一個類型為B的對象,反之不成立,因此B比D表現出更加一般化的…

Effective C++學習第十天

條款36:絕不重新定義繼承而來的non-virtual函數non-virtual函數執行的是靜態綁定,在編譯器就已經決定,因此對象對用的函數只和指針的類型有關,而與指針所指的對象無關;記住non-virtual函數的性質:不變性凌駕…

Redis運維和開發學習筆記(7) 內存管理和過期策略

Redis運維和開發學習筆記(7) 內存管理和過期策略 文章目錄Redis運維和開發學習筆記(7) 內存管理和過期策略內存回收策略惰性刪除定時任務刪除maxmemory過期策略allkeys-lru主從搭建測試搭建完畢主從測試結果volatile-lru測試結果volatile-ttl測試結果allkeys-lru內存回收策略 …

Effective C++學習第十一天

條款41:了解隱式接口和編譯期多態面向對象編程世界總是以顯式接口(源碼可見的接口)和運行期多態(virtual)解決問題;對于templates及泛型編程的世界,隱式接口和編譯期多態顯得更加重要&#xff1…

Redis源碼分析(零)學習路徑筆記

文章目錄第一階段第二階段 熟悉Redis的內存編碼結構第三階段 熟悉Redis數據類型的實現第四階段 熟悉Redis數據庫的實現第五階段 熟悉客戶端和服務器端的代碼實現第六階段 這一階段主要是熟悉Redis多機部分的代碼實現關于測試方面的文件有一些工具類的文件如下SORT命令的實現一些…

Effective C++學習第十二天

條款47:請使用traits classes表現類型信息STL有五類迭代器分類,input迭代器(只讀,一次,向前)、output迭代器(可寫,一次,向前)、forward迭代器(讀/…

Redis源碼分析(一)redis.c //redis-server.c

Redis源碼分析(一)redis.c //redis-server.c 入口函數 int main() 4450 int main(int argc, char **argv) {4451 initServerConfig();4452 if (argc 2) {4453 ResetServerSaveParams();4454 loadServerConfig(argv[1]);4455 …