Redis-redis.conf 详解

############################################## 基本设置 ########################################
# redis默认是不作为守护进程来运行的,如果你需要可以改为'yes'(设置为守护进程)
# 当作为守护进程时,redis会把进程ID写到/var/run/redis.pid (默认)文件中
daemonize no (一般改为yes)
# 作用:redis采用的是单进程多线程的模式。当redis.conf中选项daemonize设置成yes时,代表开启守护进程模式。
#在该模式下,redis会在后台运行,并将进程pid号写入至redis.conf选项pidfile设置的文件中,此时redis将一直运行,除非手动kill该进程。
# 但当daemonize选项设置成no时,当前界面将进入redis的命令行界面,exit强制退出或者关闭连接工具(putty,xshell等)都会导致redis进程退出。
# 服务端开发的大部分应用都是采用后台运行的模式

# 当redis作为守护进程他的pid写到的文件位置。
pidfile /var/run/redis.pid

# redis默认端口,如果设置为0那么redis就不会监听TCP套接字了
port 6379

# 如果有需要可以bind一个多个ip,注释了表示所有ip都能访问
bind 127.0.0.1

# 指定用于监听传入连接的unix套接字的路径,这个没有默认值,所以如果没有设置那么redis就不会监听unix套接字
unixsocket /tmp/redis.sock

# 权限为755
unixsocketperm 755

# 一个用户空闲多久后断开连接,设置为0,永远不断开连接
timeout 0

# 日志等级
# 可以在如下选项中选择:
# debug:很多信息,试用于开发环境和测试环境中
# verbose: 很多精简的信息,但是比debug少
# notice: 比较详细的详细,一般用于生产环境
# warning:非常严重的错误。
loglevel verbose

# 用于指明日志文件名称,也可以设置为stdout来在屏幕上输出。
# 如果设置为stdout,而且设置redis设置为守护进程的话那么会默认发送到 /dev/null
logfile stdout

# 如果要使用系统日志记录器只要改为yes就可以了
# 之后根据你的需要配置一下。
syslog-enabled no

# 设置syslog的用户
syslog-ident redis

# 设置syslog的设备,在local0~local7
syslog-facility local0

#设置数据库个数。默认数据库是 DB 0,你可以通过SELECT <dbid> WHERE dbid(0~'databases' - 1)来为每个连接使用不同的数据库。
databases 16

############################################## 快照 ########################################
# 保存到硬盘上
# save <seconds> <changes>
# 会在指定秒数和变动之后写入磁盘
# 例子:
# 15分钟(900秒)之后  必须且至少有一次变动
# 5分钟 (300秒)之后必须且至少有10次变动
# 1分钟(60秒)之后必须且至少有1000次变动
# 如果你不想写入磁盘那么可以删除save
save 900 1
save 300 10
save 60 10000

# 当导出到 .rdb 数据库时是否用LZF压缩字符串对象。 
# 默认设置为 "yes",所以几乎总是生效的。 
# 如果你想节省CPU的话你可以把这个设置为 "no",但是如果你有可压缩的key的话,那数据文件就会更大了。
rdbcompression yes

# 数据库文件名
dbfilename dump.rdb

# 工作目录 
# 数据库会写到这个目录下,文件名就是上面的 "dbfilename" 的值。 
# 累加文件也放这里。 
# 注意你这里指定的必须是目录,不是文件名。
dir ./

############################################## 同步 ########################################

# 主从同步。通过 slaveof 配置来实现Redis实例的备份。 
# 注意,这里是本地从远端复制数据。也就是说,本地可以有不同的数据库文件、绑定不同的IP、监听不同的端口。
slaveof <masterip> <masterport>

# 如果master设置了密码(通过下面的 "requirepass" 选项来配置),那么slave在开始同步之前必须进行身份验证,否则它的同步请求会被拒绝
masterauth <master-password>

# 当一个slave失去和master的连接,或者同步正在进行中,slave的行为有两种可能: 
# 
# 1) 如果 slave-serve-stale-data 设置为 "yes" (默认值),slave会继续响应客户端请求,可能是正常数据,也可能是还没获得值的空数据。 
# 2) 如果 slave-serve-stale-data 设置为 "no",slave会回复"正在从master同步(SYNC with master in progress)"来处理各种请求,除了 INFO 和 SLAVEOF 命令。
slave-serve-stale-data yes

# slave根据指定的时间间隔向服务器发送ping请求。 
# 时间间隔可以通过 repl_ping_slave_period 来设置。 
# 默认10。
repl-ping-slave-period 10

# 下面的选项设置了大块数据I/O、向master请求数据和ping响应的过期时间。 
# 默认值60秒。 
# 一个很重要的事情是:确保这个值比 repl-ping-slave-period 大,否则master和slave之间的传输过期时间比预想的要短。
repl-timeout 60

# 从优先级是在INFO中输出的整数。他会在主停止工作后sentinel选择一个从作为主时使用
slave-priority 100
############################################## 安全 ########################################
# 要求客户端在处理任何命令时都要验证身份和密码。 
# 这在你信不过来访者时很有用。 
# 为了向后兼容的话,这段应该注释掉。而且大多数人不需要身份验证(例如:它们运行在自己的服务器上。) 
# 警告:因为Redis太快了,所以居心不良的人可以每秒尝试150k的密码来试图破解密码。 
# 这意味着你需要一个高强度的密码,否则破解太容易了。
# requirepass foobared
设置密码

# 命令重命名 
# 在共享环境下,可以为危险命令改变名字。比如,你可以为 CONFIG 改个其他不太容易猜到的名字,这样你自己仍然可以使用,而别人却没法做坏事了。 
# 例如: 
# rename-command CONFIG b840fc02d524045429941cc15f59e41cb7be6c52 
# 甚至也可以通过给命令赋值一个空字符串来完全禁用这条命令:
rename-command CONFIG ""

############################################## 限制 ########################################
# 设置最多同时连接客户端数量。 
# 默认没有限制,这个关系到Redis进程能够打开的文件描述符数量。 
# 特殊值"0"表示没有限制。 
# 一旦达到这个限制,Redis会关闭所有新连接并发送错误"达到最大用户数上限(max number of clients reached)" 
maxclients 128

# 不要用比设置的上限更多的内存。一旦内存使用达到上限,Redis会根据选定的回收策略(参见:maxmemmory-policy)删除key。 
# 如果因为删除策略问题Redis无法删除key,或者策略设置为 "noeviction",Redis会回复需要更多内存的错误信息给命令。 
# 例如,SET,LPUSH等等。但是会继续合理响应只读命令,比如:GET。 
# 在使用Redis作为LRU缓存,或者为实例设置了硬性内存限制的时候(使用 "noeviction" 策略)的时候,这个选项还是满有用的。 
# 警告:当一堆slave连上达到内存上限的实例的时候,响应slave需要的输出缓存所需内存不计算在使用内存当中。 
# 这样当请求一个删除掉的key的时候就不会触发网络问题/重新同步的事件,然后slave就会收到一堆删除指令,直到数据库空了为止。 
# 简而言之,如果你有slave连上一个master的话,那建议你把master内存限制设小点儿,确保有足够的系统内存用作输出缓存。 
# (如果策略设置为"noeviction"的话就不无所谓了) 
maxmemory <bytes>

# 内存策略:如果达到内存限制了,Redis如何删除key。你可以在下面五个策略里面选: 
# 
# volatile-lru -> 根据LRU算法生成的过期时间来删除。 
# allkeys-lru -> 根据LRU算法删除任何key。 
# volatile-random -> 根据过期设置来随机删除key。 
# allkeys->random -> 无差别随机删。 
# volatile-ttl -> 根据最近过期时间来删除(辅以TTL) 
# noeviction -> 谁也不删,直接在写操作时返回错误。 
# 
# 注意:对所有策略来说,如果Redis找不到合适的可以删除的key都会在写操作时返回一个错误。 
# 
# 这里涉及的命令:set setnx setex append 
# incr decr rpush lpush rpushx lpushx linsert lset rpoplpush sadd 
# sinter sinterstore sunion sunionstore sdiff sdiffstore zadd zincrby 
# zunionstore zinterstore hset hsetnx hmset hincrby incrby decrby 
# getset mset msetnx exec sort 
# 
# 默认值如下:
maxmemory-policy volatile-lru

# LRU和最小TTL算法的实现都不是很精确,但是很接近(为了省内存),所以你可以用样例做测试。 
# 例如:默认Redis会检查三个key然后取最旧的那个,你可以通过下面的配置项来设置样本的个数。
maxmemory-samples 3

############################################## 纯累加模式 ########################################
# 默认情况下,Redis是异步的把数据导出到磁盘上。这种情况下,当Redis挂掉的时候,最新的数据就丢了。 
# 如果不希望丢掉任何一条数据的话就该用纯累加模式:一旦开启这个模式,Redis会把每次写入的数据在接收后都写入 appendonly.aof 文件。 
# 每次启动时Redis都会把这个文件的数据读入内存里。 
# 
# 注意,异步导出的数据库文件和纯累加文件可以并存(你得把上面所有"save"设置都注释掉,关掉导出机制)。 
# 如果纯累加模式开启了,那么Redis会在启动时载入日志文件而忽略导出的 dump.rdb 文件。 
# 
# 重要:查看 BGREWRITEAOF 来了解当累加日志文件太大了之后,怎么在后台重新处理这个日志文件
appendonly no

# 纯累加文件名字(默认:"appendonly.aof")
appendfilename appendonly.aof

# fsync() 请求操作系统马上把数据写到磁盘上,不要再等了。 
# 有些操作系统会真的把数据马上刷到磁盘上;有些则要磨蹭一下,但是会尽快去做。 
# Redis支持三种不同的模式: 
# no:不要立刻刷,只有在操作系统需要刷的时候再刷。比较快。 
# always:每次写操作都立刻写入到aof文件。慢,但是最安全。 
# everysec:每秒写一次。折衷方案。 
# 默认的 "everysec" 通常来说能在速度和数据安全性之间取得比较好的平衡。 
# 如果你真的理解了这个意味着什么,那么设置"no"可以获得更好的性能表现(如果丢数据的话,则只能拿到一个不是很新的快照); 
# 或者相反的,你选择 "always" 来牺牲速度确保数据安全、完整。 
# 如果拿不准,就用 "everysec" 
# appendfsync always
appendfsync everysec
# appendfsync no

# 如果AOF的同步策略设置成 "always" 或者 "everysec",那么后台的存储进程(后台存储或写入AOF日志)会产生很多磁盘I/O开销。 
# 某些Linux的配置下会使Redis因为 fsync() 而阻塞很久。 
# 注意,目前对这个情况还没有完美修正,甚至不同线程的 fsync() 会阻塞我们的 write(2) 请求。 
# 
# 为了缓解这个问题,可以用下面这个选项。它可以在 BGSAVE 或 BGREWRITEAOF 处理时阻止 fsync()。 
# 
# 这就意味着如果有子进程在进行保存操作,那么Redis就处于"不可同步"的状态。 
# 这实际上是说,在最差的情况下可能会丢掉30秒钟的日志数据。(默认Linux设定) 
# 
# 如果你有延迟的问题那就把这个设为 "yes",否则就保持 "no",这是保存持久数据的最安全的方式。
no-appendfsync-on-rewrite no

# 自动重写AOF文件 
# 如果AOF日志文件大到指定百分比,Redis能够通过 BGREWRITEAOF 自动重写AOF日志文件。 
# 
# 工作原理:Redis记住上次重写时AOF日志的大小(或者重启后没有写操作的话,那就直接用此时的AOF文件), 
# 基准尺寸和当前尺寸做比较。如果当前尺寸超过指定比例,就会触发重写操作。 
# 
# 你还需要指定被重写日志的最小尺寸,这样避免了达到约定百分比但尺寸仍然很小的情况还要重写。 
# 指定百分比为0会禁用AOF自动重写特性。
auto-aof-rewrite-percentage 100
auto-aof-rewrite-min-size 64mb

############################################## 慢日志 ########################################
# Redis慢查询日志可以记录超过指定时间的查询。运行时间不包括各种I/O时间。 
# 例如:连接客户端,发送响应数据等。只计算命令运行的实际时间(这是唯一一种命令运行线程阻塞而无法同时为其他请求服务的场景) 
# 
# 你可以为慢查询日志配置两个参数:一个是超标时间,单位为微妙,记录超过个时间的命令。 
# 另一个是慢查询日志长度。当一个新的命令被写进日志的时候,最老的那个记录会被删掉。 
# 
# 下面的时间单位是微秒,所以1000000就是1秒。注意,负数时间会禁用慢查询日志,而0则会强制记录所有命令。 
slowlog-log-slower-than 10000

# 这个长度没有限制。只要有足够的内存就行。你可以通过 SLOWLOG RESET 来释放内存。
slowlog-max-len 128


############################################## 虚拟内存 ########################################
### 警告!虚拟内存在Redis 2.4是反对的。 
### 非常不鼓励使用虚拟内存!!
# 虚拟内存可以使Redis在内存不够的情况下仍然可以将所有数据序列保存在内存里。 
# 为了做到这一点,高频key会调到内存里,而低频key会转到交换文件里,就像操作系统使用内存页一样。 
# 
# 要使用虚拟内存,只要把 "vm-enabled" 设置为 "yes",并根据需要设置下面三个虚拟内存参数就可以了。
vm-enabled no
# vm-enabled yes

# 这是交换文件的路径。估计你猜到了,交换文件不能在多个Redis实例之间共享,所以确保每个Redis实例使用一个独立交换文件。 
# 最好的保存交换文件(被随机访问)的介质是固态硬盘(SSD)。 
# *** 警告 *** 如果你使用共享主机,那么默认的交换文件放到 /tmp 下是不安全的。 
# 创建一个Redis用户可写的目录,并配置Redis在这里创建交换文件。 
vm-swap-file /tmp/redis.swap

# "vm-max-memory" 配置虚拟内存可用的最大内存容量。 
# 如果交换文件还有空间的话,所有超标部分都会放到交换文件里。 
# 
# "vm-max-memory" 设置为0表示系统会用掉所有可用内存。 
# 这默认值不咋地,只是把你能用的内存全用掉了,留点余量会更好。 
# 例如,设置为剩余内存的60%-80%
vm-max-memory 0

# Redis交换文件是分成多个数据页的。 
# 一个可存储对象可以被保存在多个连续页里,但是一个数据页无法被多个对象共享。 
# 所以,如果你的数据页太大,那么小对象就会浪费掉很多空间。 
# 如果数据页太小,那用于存储的交换空间就会更少(假定你设置相同的数据页数量) 
# 
# 如果你使用很多小对象,建议分页尺寸为64或32个字节。 
# 如果你使用很多大对象,那就用大一些的尺寸。 
# 如果不确定,那就用默认值 :) 
vm-page-size 32

# 交换文件里数据页总数。 
# 根据内存中分页表(已用/未用的数据页分布情况),磁盘上每8个数据页会消耗内存里1个字节。 
# 
# 交换区容量 = vm-page-size * vm-pages 
# 
# 根据默认的32字节的数据页尺寸和134217728的数据页数来算,Redis的数据页文件会占4GB,而内存里的分页表会消耗16MB内存。 
# 
# 为你的应验程序设置最小且够用的数字比较好,下面这个默认值在大多数情况下都是偏大的。 
vm-pages 134217728

# 同时可运行的虚拟内存I/O线程数。 
# 这些线程可以完成从交换文件进行数据读写的操作,也可以处理数据在内存与磁盘间的交互和编码/解码处理。 
# 多一些线程可以一定程度上提高处理效率,虽然I/O操作本身依赖于物理设备的限制,不会因为更多的线程而提高单次读写操作的效率。 
# 
# 特殊值0会关闭线程级I/O,并会开启阻塞虚拟内存机制。 
vm-max-threads 4

############################################## 高级设置 ########################################
# 当有大量数据时,适合用哈希编码(需要更多的内存),元素数量上限不能超过给定限制。 
# 你可以通过下面的选项来设定这些限制: 
hash-max-zipmap-entries 512 
hash-max-zipmap-value 64 

# 与哈希相类似,数据元素较少的情况下,可以用另一种方式来编码从而节省大量空间。 
# 这种方式只有在符合下面限制的时候才可以用: 
list-max-ziplist-entries 512
list-max-ziplist-value 64

# 还有这样一种特殊编码的情况:数据全是64位无符号整型数字构成的字符串。 
# 下面这个配置项就是用来限制这种情况下使用这种编码的最大上限的。
set-max-intset-entries 512

# 与第一、第二种情况相似,有序序列也可以用一种特别的编码方式来处理,可节省大量空间。 
# 这种编码只适合长度和元素都符合下面限制的有序序列: 
zset-max-ziplist-entries 128 
zset-max-ziplist-value 64

# 哈希刷新,每100个CPU毫秒会拿出1个毫秒来刷新Redis的主哈希表(顶级键值映射表)。 
# redis所用的哈希表实现(见dict.c)采用延迟哈希刷新机制:你对一个哈希表操作越多,哈希刷新操作就越频繁; 
# 反之,如果服务器非常不活跃那么也就是用点内存保存哈希表而已。 
# 
# 默认是每秒钟进行10次哈希表刷新,用来刷新字典,然后尽快释放内存。 
# 
# 建议: 
# 如果你对延迟比较在意的话就用 "activerehashing no",每个请求延迟2毫秒不太好嘛。 
# 如果你不太在意延迟而希望尽快释放内存的话就设置 "activerehashing yes"。
activerehashing yes

############################################## 包含 ########################################
# 包含一个或多个其他配置文件。 
# 这在你有标准配置模板但是每个redis服务器又需要个性设置的时候很有用。 
# 包含文件特性允许你引人其他配置文件,所以好好利用吧。
include /path/to/local.conf 
include /path/to/other.conf
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,992评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,212评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,535评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,197评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,310评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,383评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,409评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,191评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,621评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,910评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,084评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,763评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,403评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,083评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,318评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,946评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,967评论 2 351

推荐阅读更多精彩内容