主頁 > 資料庫 > Redis組態檔詳解

Redis組態檔詳解

2020-09-12 19:31:29 資料庫

UNITS單位

配置大小單位,開頭定義了一些基本的度量單位,只支持bytes,不支持bit.單位大小寫不敏感 1GB 1Gb 1gB 是一樣的,

# 1g => 1000000000 bytes
# 1gb => 1024*1024*1024 bytes

INCLUDES包含

  • 和Struts2組態檔類似,可以通過includes包含,redis.conf可以作為總閘,包含其他組態檔,

    Include檔案可以加載其他額外組態檔,其他組態檔(other.conf)中如果含有與此檔案重復的配置項,將不會被重寫,

    換句話說,在此匯入后,會被本檔案(redis.conf)下面定義的同類配置重寫,即使用最新的配置,各個組態檔形成互補配置,

# include /path/to/local.conf
# include /path/to/other.conf

GENERAL通用

  • daemonize yes

    默認情況下,Redis不是在后臺運行的,如果需要在后臺運行,把該項的值更改為 yes,

  • pidfile /var/run/redis_6379.pid

    當Redis在后臺運行的時候,Redis 默認會把 pid 檔案放在/var/run/redis_6379.pid,你可以配置到其他地址,當運行多個redis服務時,需要指定不同的 pid檔案和埠

NETWORK網路

  • port 6379

    監聽埠,默認為 6379

  • #bind 127.0.0.1

    指定Redis只接收來自于該IP地址的請求,如果不進行設定,那么將處理所有請求,在生產環境中為了安全最好設定該項,默認注釋掉,不開啟,

  • tcp-backlog 511

    設定tcp的backlog,backlog其實是一個連接佇列,backlog佇列總和=未完成三次握手佇列 已經完成三次握手佇列,在高并發環境下你需要一個高backlog值來避免慢客戶端連接問題,注意Linux內核會將這個值減小到/proc/sys/net/core/somaxconn的值,所以需要確認增大somaxconntcp_max_syn_backlog兩個值來達到想要的效果,

  • timeout 0

    設定客戶端連接時的超時時間,單位為秒,當客戶端在這段時間內沒有發出任何指令,那么關閉該連接

  • Tcp-keepalive 300

    單位為秒,指定 TCP 連接是否為長連接,"偵探"信號有 server 端維護,默認為 0,表示禁用,則不會進行Keepalive檢測

  • loglevel notice

    log等級分為4級,debug,verbose, notice,和warning,生產環境下一般開啟 notice

  • logfile stdout

    配置log檔案地址,默認使用標準輸出,即列印在命令列終端的視窗上,修改為日志檔案目錄

  • Syslog-enabled no

    是否把日志輸出到syslog中

  • Syslog-ident redis

    指定syslog里的日志標志

  • Syslog-facility local0

    指定syslog設備,值可以是USER或LOCAL0-LOCAL7

  • databases 16

    設定資料庫的個數,可以使用SELECT命令來切換資料庫,默認 16 個庫

SNAPSHOTTING快照

  • save 900 1
    save 300 10
    save 60 10000

    保存資料快照的頻率,即將資料持久化到 dump.rdb 檔案中的頻度,用來描述"在多少秒期間至少多少個變更操作"觸發 snapshot 資料保存動作,默認設定,意思是:

    if(在 60  秒之內有 10000 個 keys  發生變化時){
    進行鏡像備份
    }else if(在 300  秒之內有 10 個 keys  發生了變化){
    進行鏡像備份
    }else if(在 900  秒之內有 1 個 keys  發生了變化){
    進行鏡像備份
    }
    
  • stop-writes-on-bgsave-error yes

    當持久化出現錯誤時,是否依然繼續進行作業,是否終止所有的客戶端 write 請求,默認設定"yes"表示終止,一旦 snapshot 資料保存故障,那么此 server 為只讀服務,如果為"no",那么此次 snapshot 將失敗,但下一次 snapshot 不會受到影響,不過如果出現故障,資料只能恢復到"最近一個成功點"

  • rdbcompression yes

    對于存盤到磁盤中的快照,可以設定是否進行壓縮存盤,如果是的話,redis會采用LZF演算法進行壓縮,在進行資料鏡像備份時,是否啟用 rdb 檔案壓縮手段,默認為 yes,

    壓縮可能需要額外的cpu 開支,不過這能夠有效的減小 rdb 檔案的大,有利于存盤/備份/傳輸/資料恢復,如果你不想消耗CPU來進行壓縮的話,可以設定為關閉此功能,

  • rdbchecksum yes

    在存盤快照后,還可以讓redis使用CRC64演算法來進行資料校驗,但是這樣做會增加大約10%的性能消耗,如果希望獲取到最大的性能提升,可以關閉此功能,

  • dbfilename dump.rdb

    鏡像備份檔案的檔案名,默認為 dump.rdb

  • dir ./
    資料庫鏡像備份的檔案 rdb/AOF 檔案放置的路徑,這里的路徑跟檔案名要分開配置是因為
    Redis 在進行備份時,先會將當前資料庫的狀態寫入到一個臨時檔案中,等備份完成時,
    再把該臨時檔案替換為上面所指定的檔案,而這里的臨時檔案和上面所配置的備份檔案都會
    放在這個指定的路徑當中,

REPLICATION復制

暫略

SECURITY安全

訪問密碼的查看、設定和取消

暫略

LIMITS限制

  • maxclients 10000

設定redis同時可以與多少個客戶端進行連接,默認情況下為10000個客戶端,當你無法設定行程檔案句柄限制,redis會設定為當前的檔案句柄限制值減去32,因為redis會為自身內部處理邏輯留一些句柄出來,如果達到了此限制,redis則會拒絕新的連接請求,并且向這些連接請求方發出“max number of clients reached”以作回應,

  • maxmemory <bytes>

    設定redis可以使用的記憶體量,一旦到達記憶體使用上限,redis將會試圖移除內部資料,移除規則可以通過maxmemory-policy來指定,如果redis無法根據移除規則來移除記憶體中的資料,或者設定了“不允許移除”,
    那么redis則會針對那些需要申請記憶體的指令回傳錯誤資訊,比如SET、LPUSH等,

    但是對于無記憶體申請的指令,仍然會正常回應,比如GET等,如果你的redis是主redis(說明你的redis有從redis),那么在設定記憶體使用上限時,需要在系統中留出一些記憶體空間給同步佇列快取,只有在你設定的是“不移除”的情況下,才不用考慮這個因素,

  • Maxmemory-policy noeviction

    (1)volatile-lru:使用LRU演算法移除key,只對設定了過期時間的鍵
    (2)allkeys-lru:使用LRU演算法移除key
    (3)volatile-random:在過期集合中移除隨機的key,只對設定了過期時間的鍵
    (4)allkeys-random:移除隨機的key
    (5)volatile-ttl:移除那些TTL值最小的key,即那些最近要過期的key
    (6)noeviction:不進行移除,針對寫操作,只是回傳錯誤資訊

  • maxmemory-samples 5

    設定樣本數量,LRU演算法和最小TTL演算法都并非是精確的演算法,而是估算值,所以你可以設定樣本的大小,
    redis默認會檢查這么多個key并選擇其中LRU的那個

APPEND ONLY MODE追加

暫略

總結:常見配置redis.conf介紹

redis.conf 配置項說明如下:

  1. Redis默認不是以守護行程的方式運行,可以通過該配置項修改,使用yes啟用守護行程

    daemonize no
    
  2. 當Redis以守護行程方式運行時,Redis默認會把pid寫入/var/run/redis.pid檔案,可以通過pidfile指定

    pidfile /var/run/redis.pid
    
  3. 指定Redis監聽埠,默認埠為6379,作者在自己的一篇博文中解釋了為什么選用6379作為默認埠,因為6379在手機按鍵上MERZ對應的號碼,而MERZ取自意大利歌女Alessia Merz的名字

    port 6379
    
  4. 系結的主機地址

    bind 127.0.0.1
    
  5. 當客戶端閑置多長時間后關閉連接,如果指定為0,表示關閉該功能

    timeout 300
    
  6. 指定日志記錄級別,Redis總共支持四個級別:debug、verbose、notice、warning,默認為verbose

    loglevel verbose
    
  7. 日志記錄方式,默認為標準輸出,如果配置Redis為守護行程方式運行,而這里又配置為日志記錄方式為標準輸出,則日志將會發送給/dev/null

    logfile stdout
    
  8. 設定資料庫的數量,默認資料庫為0,可以使用SELECT

    databases 16
    
  9. 指定在多長時間內,有多少次更新操作,就將資料同步到資料檔案,可以多個條件配合
    save <seconds> <changes>
    Redis默認組態檔中提供了三個條件:

    save 900 1
    save 300 10
    save 60 10000
    

分別表示900秒(15分鐘)內有1個更改,300秒(5分鐘)內有10個更改以及60秒內有10000個更改,

  1. 指定存盤至本地資料庫時是否壓縮資料,默認為yes,Redis采用LZF壓縮,如果為了節省CPU時間,可以關閉該選項,但會導致資料庫檔案變的巨大

    rdbcompression yes
    
  2. 指定本地資料庫檔案名,默認值為dump.rdb

    dbfilename dump.rdb
    
  3. 指定本地資料庫存放目錄

    dir ./
    
  4. 設定當本機為slav服務時,設定master服務的IP地址及埠,在Redis啟動時,它會自動從master進行資料同步

    slaveof <masterip> <masterport>
    
  5. 當master服務設定了密碼保護時,slav服務連接master的密碼

    masterauth <master-password>
    
  6. 設定Redis連接密碼,如果配置了連接密碼,客戶端在連接Redis時需要通過AUTH

    requirepass foobared
    
  7. 設定同一時間最大客戶端連接數,默認無限制,Redis可以同時打開的客戶端連接數為Redis行程可以打開的最大檔案描述符數,如果設定 maxclients 0,表示不作限制,當客戶端連接數到達限制時,Redis會關閉新的連接并向客戶端回傳max number of clients reached錯誤資訊

    maxclients 128
    
  8. 指定Redis最大記憶體限制,Redis在啟動時會把資料加載到記憶體中,達到最大記憶體后,Redis會先嘗試清除已到期或即將到期的Key,當此方法處理 后,仍然到達最大記憶體設定,將無法再進行寫入操作,但仍然可以進行讀取操作,Redis新的vm機制,會把Key存放記憶體,Value會存放在swap區

    maxmemory <bytes>
    
  9. 指定是否在每次更新操作后進行日志記錄,Redis在默認情況下是異步的把資料寫入磁盤,如果不開啟,可能會在斷電時導致一段時間內的資料丟失,因為 redis本身同步資料檔案是按上面save條件來同步的,所以有的資料會在一段時間內只存在于記憶體中,默認為no

    appendonly no
    
  10. 指定更新日志檔案名,默認為appendonly.aof

    appendfilename appendonly.aof
    
  11. 指定更新日志條件,共有3個可選值:
    no:表示等作業系統進行資料快取同步到磁盤(快)
    always:表示每次更新操作后手動呼叫fsync()將資料寫到磁盤(慢,安全)
    everysec:表示每秒同步一次(折衷,默認值)
    appendfsync everysec

  12. 指定是否啟用虛擬記憶體機制,默認值為no,簡單的介紹一下,VM機制將資料分頁存放,由Redis將訪問量較少的頁即冷資料swap到磁盤上,訪問多的頁面由磁盤自動換出到記憶體中(在后面的文章我會仔細分析Redis的VM機制)

    vm-enabled no
    
  13. 虛擬記憶體檔案路徑,默認值為/tmp/redis.swap,不可多個Redis實體共享

    vm-swap-file /tmp/redis.swap
    
  14. 將所有大于vm-max-memory的資料存入虛擬記憶體,無論vm-max-memory設定多小,所有索引資料都是記憶體存盤的(Redis的索引資料 就是keys),也就是說,當vm-max-memory設定為0的時候,其實是所有value都存在于磁盤,默認值為0

    vm-max-memory 0
    
  15. Redis swap檔案分成了很多的page,一個物件可以保存在多個page上面,但一個page上不能被多個物件共享,vm-page-size是要根據存盤的 資料大小來設定的,作者建議如果存盤很多小物件,page大小最好設定為32或者64bytes;如果存盤很大大物件,則可以使用更大的page,如果不 確定,就使用默認值

    vm-page-size 32
    
  16. 設定swap檔案中的page數量,由于頁表(一種表示頁面空閑或使用的bitmap)是在放在記憶體中的,,在磁盤上每8個pages將消耗1byte的記憶體,

    vm-pages 134217728
    
  17. 設定訪問swap檔案的執行緒數,最好不要超過機器的核數,如果設定為0,那么所有對swap檔案的操作都是串行的,可能會造成比較長時間的延遲,默認值為4

    vm-max-threads 4
    
  18. 設定在向客戶端應答時,是否把較小的包合并為一個包發送,默認為開啟

    glueoutputbuf yes
    
  19. 指定在超過一定的數量或者最大的元素超過某一臨界值時,采用一種特殊的哈希演算法

    hash-max-zipmap-entries 64
    hash-max-zipmap-value 512
    
  20. 指定是否激活重置哈希,默認為開啟(后面在介紹Redis的哈希演算法時具體介紹)

    activerehashing yes
    
  21. 指定包含其它的組態檔,可以在同一主機上多個Redis實體之間使用同一份組態檔,而同時各個實體又擁有自己的特定組態檔

    include /path/to/local.conf
    

轉載請註明出處,本文鏈接:https://www.uj5u.com/shujuku/16455.html

標籤:NoSQL

上一篇:好訊息,新一代powerbuilder 將于2017年1月發布,值得期待!

下一篇:基于SpringBoot集成測驗遠程連接的Redis服務

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • GPU虛擬機創建時間深度優化

    **?桔妹導讀:**GPU虛擬機實體創建速度慢是公有云面臨的普遍問題,由于通常情況下創建虛擬機屬于低頻操作而未引起業界的重視,實際生產中還是存在對GPU實體創建時間有苛刻要求的業務場景。本文將介紹滴滴云在解決該問題時的思路、方法、并展示最終的優化成果。 從公有云服務商那里購買過虛擬主機的資深用戶,一 ......

    uj5u.com 2020-09-10 06:09:13 more
  • 可編程網卡芯片在滴滴云網路的應用實踐

    **?桔妹導讀:**隨著云規模不斷擴大以及業務層面對延遲、帶寬的要求越來越高,采用DPDK 加速網路報文處理的方式在橫向縱向擴展都出現了局限性。可編程芯片成為業界熱點。本文主要講述了可編程網卡芯片在滴滴云網路中的應用實踐,遇到的問題、帶來的收益以及開源社區貢獻。 #1. 資料中心面臨的問題 隨著滴滴 ......

    uj5u.com 2020-09-10 06:10:21 more
  • 滴滴資料通道服務演進之路

    **?桔妹導讀:**滴滴資料通道引擎承載著全公司的資料同步,為下游實時和離線場景提供了必不可少的源資料。隨著任務量的不斷增加,資料通道的整體架構也隨之發生改變。本文介紹了滴滴資料通道的發展歷程,遇到的問題以及今后的規劃。 #1. 背景 資料,對于任何一家互聯網公司來說都是非常重要的資產,公司的大資料 ......

    uj5u.com 2020-09-10 06:11:05 more
  • 滴滴AI Labs斬獲國際機器翻譯大賽中譯英方向世界第三

    **桔妹導讀:**深耕人工智能領域,致力于探索AI讓出行更美好的滴滴AI Labs再次斬獲國際大獎,這次獲獎的專案是什么呢?一起來看看詳細報道吧! 近日,由國際計算語言學協會ACL(The Association for Computational Linguistics)舉辦的世界最具影響力的機器 ......

    uj5u.com 2020-09-10 06:11:29 more
  • MPP (Massively Parallel Processing)大規模并行處理

    1、什么是mpp? MPP (Massively Parallel Processing),即大規模并行處理,在資料庫非共享集群中,每個節點都有獨立的磁盤存盤系統和記憶體系統,業務資料根據資料庫模型和應用特點劃分到各個節點上,每臺資料節點通過專用網路或者商業通用網路互相連接,彼此協同計算,作為整體提供 ......

    uj5u.com 2020-09-10 06:11:41 more
  • 滴滴資料倉庫指標體系建設實踐

    **桔妹導讀:**指標體系是什么?如何使用OSM模型和AARRR模型搭建指標體系?如何統一流程、規范化、工具化管理指標體系?本文會對建設的方法論結合滴滴資料指標體系建設實踐進行解答分析。 #1. 什么是指標體系 ##1.1 指標體系定義 指標體系是將零散單點的具有相互聯系的指標,系統化的組織起來,通 ......

    uj5u.com 2020-09-10 06:12:52 more
  • 單表千萬行資料庫 LIKE 搜索優化手記

    我們經常在資料庫中使用 LIKE 運算子來完成對資料的模糊搜索,LIKE 運算子用于在 WHERE 子句中搜索列中的指定模式。 如果需要查找客戶表中所有姓氏是“張”的資料,可以使用下面的 SQL 陳述句: SELECT * FROM Customer WHERE Name LIKE '張%' 如果需要 ......

    uj5u.com 2020-09-10 06:13:25 more
  • 滴滴Ceph分布式存盤系統優化之鎖優化

    **桔妹導讀:**Ceph是國際知名的開源分布式存盤系統,在工業界和學術界都有著重要的影響。Ceph的架構和演算法設計發表在國際系統領域頂級會議OSDI、SOSP、SC等上。Ceph社區得到Red Hat、SUSE、Intel等大公司的大力支持。Ceph是國際云計算領域應用最廣泛的開源分布式存盤系統, ......

    uj5u.com 2020-09-10 06:14:51 more
  • es~通過ElasticsearchTemplate進行聚合~嵌套聚合

    之前寫過《es~通過ElasticsearchTemplate進行聚合操作》的文章,這一次主要寫一個嵌套的聚合,例如先對sex集合,再對desc聚合,最后再對age求和,共三層嵌套。 Aggregations的部分特性類似于SQL語言中的group by,avg,sum等函式,Aggregation ......

    uj5u.com 2020-09-10 06:14:59 more
  • 爬蟲日志監控 -- Elastc Stack(ELK)部署

    傻瓜式部署,只需替換IP與用戶 導讀: 現ELK四大組件分別為:Elasticsearch(核心)、logstash(處理)、filebeat(采集)、kibana(可視化) 下載均在https://www.elastic.co/cn/downloads/下tar包,各組件版本最好一致,配合fdm會 ......

    uj5u.com 2020-09-10 06:15:05 more
最新发布
  • day02-2-商鋪查詢快取

    功能02-商鋪查詢快取 3.商鋪詳情快取查詢 3.1什么是快取? 快取就是資料交換的緩沖區(稱作Cache),是存盤資料的臨時地方,一般讀寫性能較高。 快取的作用: 降低后端負載 提高讀寫效率,降低回應時間 快取的成本: 資料一致性成本 代碼維護成本 運維成本 3.2需求說明 如下,當我們點擊商店詳 ......

    uj5u.com 2023-04-20 08:33:24 more
  • MySQL中binlog備份腳本分享

    關于MySQL的二進制日志(binlog),我們都知道二進制日志(binlog)非常重要,尤其當你需要point to point災難恢復的時侯,所以我們要對其進行備份。關于二進制日志(binlog)的備份,可以基于flush logs方式先切換binlog,然后拷貝&壓縮到到遠程服務器或本地服務器 ......

    uj5u.com 2023-04-20 08:28:06 more
  • day02-短信登錄

    功能實作02 2.功能01-短信登錄 2.1基于Session實作登錄 2.1.1思路分析 2.1.2代碼實作 2.1.2.1發送短信驗證碼 發送短信驗證碼: 發送驗證碼的介面為:http://127.0.0.1:8080/api/user/code?phone=xxxxx<手機號> 請求方式:PO ......

    uj5u.com 2023-04-20 08:27:27 more
  • 快取與資料庫雙寫一致性幾種策略分析

    本文將對幾種快取與資料庫保證資料一致性的使用方式進行分析。為保證高并發性能,以下分析場景不考慮執行的原子性及加鎖等強一致性要求的場景,僅追求最終一致性。 ......

    uj5u.com 2023-04-20 08:26:48 more
  • sql陳述句優化

    問題查找及措施 問題查找 需要找到具體的代碼,對其進行一對一優化,而非一直把關注點放在服務器和sql平臺 降低簡化每個事務中處理的問題,盡量不要讓一個事務拖太長的時間 例如檔案上傳時,應將檔案上傳這一步放在事務外面 微軟建議 4.啟動sql定時執行計劃 怎么啟動sqlserver代理服務-百度經驗 ......

    uj5u.com 2023-04-20 08:26:35 more
  • 云時代,MySQL到ClickHouse資料同步產品對比推薦

    ClickHouse 在執行分析查詢時的速度優勢很好的彌補了MySQL的不足,但是對于很多開發者和DBA來說,如何將MySQL穩定、高效、簡單的同步到 ClickHouse 卻很困難。本文對比了 NineData、MaterializeMySQL(ClickHouse自帶)、Bifrost 三款產品... ......

    uj5u.com 2023-04-20 08:26:29 more
  • sql陳述句優化

    問題查找及措施 問題查找 需要找到具體的代碼,對其進行一對一優化,而非一直把關注點放在服務器和sql平臺 降低簡化每個事務中處理的問題,盡量不要讓一個事務拖太長的時間 例如檔案上傳時,應將檔案上傳這一步放在事務外面 微軟建議 4.啟動sql定時執行計劃 怎么啟動sqlserver代理服務-百度經驗 ......

    uj5u.com 2023-04-20 08:25:13 more
  • Redis 報”OutOfDirectMemoryError“(堆外記憶體溢位)

    Redis 報錯“OutOfDirectMemoryError(堆外記憶體溢位) ”問題如下: 一、報錯資訊: 使用 Redis 的業務介面 ,產生 OutOfDirectMemoryError(堆外記憶體溢位),如圖: 格式化后的報錯資訊: { "timestamp": "2023-04-17 22: ......

    uj5u.com 2023-04-20 08:24:54 more
  • day02-2-商鋪查詢快取

    功能02-商鋪查詢快取 3.商鋪詳情快取查詢 3.1什么是快取? 快取就是資料交換的緩沖區(稱作Cache),是存盤資料的臨時地方,一般讀寫性能較高。 快取的作用: 降低后端負載 提高讀寫效率,降低回應時間 快取的成本: 資料一致性成本 代碼維護成本 運維成本 3.2需求說明 如下,當我們點擊商店詳 ......

    uj5u.com 2023-04-20 08:24:03 more
  • day02-短信登錄

    功能實作02 2.功能01-短信登錄 2.1基于Session實作登錄 2.1.1思路分析 2.1.2代碼實作 2.1.2.1發送短信驗證碼 發送短信驗證碼: 發送驗證碼的介面為:http://127.0.0.1:8080/api/user/code?phone=xxxxx<手機號> 請求方式:PO ......

    uj5u.com 2023-04-20 08:23:11 more