redis.conf配置及说明

上传人:油条 文档编号:10178903 上传时间:2017-09-02 格式:PDF 页数:6 大小:156.95KB
返回 下载 相关 举报
redis.conf配置及说明_第1页
第1页 / 共6页
redis.conf配置及说明_第2页
第2页 / 共6页
redis.conf配置及说明_第3页
第3页 / 共6页
redis.conf配置及说明_第4页
第4页 / 共6页
redis.conf配置及说明_第5页
第5页 / 共6页
点击查看更多>>
资源描述

《redis.conf配置及说明》由会员分享,可在线阅读,更多相关《redis.conf配置及说明(6页珍藏版)》请在金锄头文库上搜索。

1、redis.conf配置及说明当前所用Redis版本为2.6/2.8,Redis.conf中已有比较详细的注释,本文根据网络资源整理,外加个人实际应用过程中遇到的一些问题,基本涵盖了Redis.conf中的绝大部分配置内容。基本设置1. 备释当配置中需要配置内存大小时,可以使用 1k, 5GB, 4M 等类似的格式,其转换方式如下(不区分大小写):1k =设置redis能够使用的最大内存。达到最大内存设置后,Redis会先尝试清除已到期或即将到期的Key(设置过expire信息的key)在删除时,按照过期时间进行删除,最早将要被过期的key将最先被删除如果已到期或即将到期的key删光,仍进行s

2、et操作,那么将返回错误此时redis将不再接收写请求,只接收get请求。maxmemory的设置比较适合于把redis当作于类似memcached 的缓存来使用13. maxmemory-policy当内存达到最大值的时候Redis会选择删除哪些数据?有五种方式可供选择# volatile-lru - 利用LRU算法移除设置过过期时间的key (LRU:最近使用 Least Recently Used )# allkeys-lru - 利用LRU算法移除任何key# volatile-random - 移除设置过过期时间的随机key# allkeys-random - remove a ra

3、ndom key, any key# volatile-ttl - 移除即将过期的key(minor TTL)# noeviction - 不移除任何可以,只是返回一个写错误# 注意:对于上面的策略,如果没有合适的key可以移除,当写的时候Redis会返回一个错误# 写命令包括: set setnx setex append# incr decr rpush lpush rpushx lpushx linsert lset rpoplpush sadd# sinter sinterstore sunion sunionstore sdiff sdiffstore zadd zincrby# z

4、unionstore zinterstore hset hsetnx hmset hincrby incrby decrby# getset mset msetnx exec sort# 默认是:# maxmemory-policy volatile-lru14. syslog-enabled no syslog-enabled设置为yes会把日志输出到系统日志,默认是no 15. syslog-ident redis 指定syslog的标示符,如果syslog-enabled是no,则这个选项无效。 16. syslog-facility local0 指定syslog 设备(facilit

5、y), 必须是USER或者LOCAL0到LOCAL7. SLOWLOG1. slowlog-log-slower-than 10000Redis slow log用来记录超过指定执行时间的查询。执行时间不包括I/O计算比如连接客户端,返回结果等,只是命令执行时间可以通过两个参数设置slow log:一个是告诉Redis执行超过多少时间被记录的参数slowlog-log-slower-than(毫秒),另一个是slow log 的长度。当一个新命令被记录的时候最早的命令将被从队列中移除负数则关闭slow log,0则会导致每个命令都被记录2. slowlog-max-len对日志长度没有限制,只

6、是要注意它会消耗内存可以通过 SLOWLOG RESET 回收被慢日志消耗的内存Snapshotting配置1. savesave ,用来描述”在多少秒期间至少多少个变更操作”触发snapshotsnapshot最终将生成新的dump.rdb文件save “”用来禁用snapshot功能例如save 300 1表示5分钟内至少一个key变更,触发snapshot2. rdbcompression yes是否启用rdb文件压缩手段,默认为yes.压缩可能需要额外的cpu开支,不过这能够有效的减小rdb文件的大小,有利于存储/备份/传输/数据恢复.3. rdbchecksum yes是否对rdb文

7、件使用CRC64校验和,默认为”yes”,那么每个rdb文件内容的末尾都会追加CRC校验和.对于其他第三方校验工具,可以很方便的检测文件的完整性4. dbfilename dump.rdb镜像备份文件的文件名5. dir ./指定rdb/AOF文件的目录位置,只能为文件夹不能为文件AOF1. appendonly no#默认情况下,Redis会异步的把数据保存到硬盘。如果你的应用场景允许因为系统崩溃等极端情况而导致最新数据丢失#的话,那这种做法已经很ok了。否则你应该打开append only模式,开启这种模式后,Redis会在#appendonly.aof文件中添加每一个写操作,这个文件会在

8、Redis启动时被读取来在内存中重新构建数据集。#注意:如果你需要,你可以同时开启append only模式和异步dumps模式(你需要注释掉上面的save表达式来禁#止dumps),这种情况下,Redis重建数据集时会优先使用appendonly.aof而忽略dump.rdb2. appendfilename appendonly.aofAOF文件名称 (默认: appendonly.aof)3. appendfsync everysec# 调用fsync()函数通知操作系统立刻向硬盘写数据# Redis支持三种同步AOF文件的策略:# no:不fsync, 只是通知OS可以flush数据了

9、,具体是否flush取决于OS.性能更好.# always: 每次写入append only 日志文件后都会fsync . 性能差,但很安全.# everysec: 没间隔1秒进行一次fsync. 折中.# 默认是everysec,按照速度和安全折中这是最好的。# 如果想让Redis能更高效的运行,你也可以设置为no,让操作系统决定什么时候去执行# 或者相反想让数据更安全你也可以设置为always# 如果不确定就用 everysec.4. no-appendfsync-on-rewrite no# AOF策略设置为always或者everysec时,后台处理进程(后台保存或者AOF日志重写)会

10、执行大量的I/O操作# 在某些Linux配置中会阻止过长的fsync()请求。注意现在没有任何修复,即使fsync在另外一个线程进行处理# 为了减缓这个问题,可以设置下面这个参数no-appendfsync-on-rewrite5. auto-aof-rewrite-percentage 100auto-aof-rewrite-min-size 64mb# append only 文件的自动重写# 当AOF 日志文件即将增长到指定百分比时,Redis可以通过调用BGREWRITEAOF 来自动重写append only文件。# 它是这么干的:Redis会记住最近一次重写后的AOF 文件size

11、。然后它会把这个size与当前size进行比较,如果当前size比指定的百分比大,就会触发重写。同样,你需要指定AOF文件被重写的最小size,这对避免虽然百分比达到了, 但是实际上文件size还是很小(这种情况没有必要重写)却导致AOF文件重写的情况很有用。# auto-aof-rewrite-percentage 设置为 0 可以关闭AOF重写功能高级配置1. hash-max-zipmap-entries 512hash-max-zipmap-value 64redis 2.0后引入了 hash 数据结构。当hash中包含超过指定元素个数并且最大的元素没有超过临界时,# hash将以一种

12、特殊的编码方式(大大减少内存使用)来存储,这里可以设置这两个临界值# Redis Hash对应Value内部实际就是一个HashMap,实际这里会有2种不同实现,# 这个Hash的成员比较少时Redis为了节省内存会采用类似一维数组的方式来紧凑存储,而不会采用真正的HashMap结构,对应的value redisObject的encoding为zipmap,# 当成员数量增大时会自动转成真正的HashMap,此时encoding为ht。2. activerehashing yes是否重置Hash表设置成yes后redis将每100毫秒使用1毫秒CPU时间来对redis的hash表重新hash,

13、可降低内存的使用当使用场景有较为严格的实时性需求,不能接受Redis时不时的对请求有2毫秒的延迟的话,把这项配置为no。如果没有这么严格的实时性要求,可以设置为 yes,以便能够尽可能快的释放内存3. list-max-ziplist-entries 512list-max-ziplist-value 64list 数据类型多少节点以下会采用去指针的紧凑存储格式。list 数据类型节点值大小小于多少字节会采用紧凑存储格式。4. set-max-intset-entries 512set数据类型内部数据如果全部是数值型,且包含多少节点以下会采用紧凑格式存储。5. zset-max-ziplist

14、-entries 128zset-max-ziplist-value 64zsort 数据类型多少节点以下会采用去指针的紧凑存储格式。zsort 数据类型节点值大小小于多少字节会采用紧凑存储格式。Replication1. slaveof将当前server做为slave,并为其指定master信息.slaveof 当本机为从服务时,设置主服务的IP及端口2. masterauth以认证的方式连接到master。 如果master中使用了”密码保护”,slave必须交付正确的授权密码,才能连接成功。“requirepass”配置项指定了当前server的密码。此配置项中值需要和master机器的

15、”requirepass”保持一致3. slave-serve-stale-data yes如果当前server是slave,那么当slave与master失去通讯时,是否继续为客户端提供服务,”yes”表示继续,”no”表示终止.在”yes”情况下,slave继续向客户端提供只读服务,有可能此时的数据已经过期.在”no”情况下,任何向此server发送的数据请求服务(包括客户端和此server的slave)都将被告知”error”,但 INFO 和SLAVEOF命令除外。VM1. vm-enabled no是否开启虚拟内存支持。redis 是一个内存数据库,当内存满时,无法接收新的写请求,所

16、以在redis2.0后,提供了虚拟内存的支持但需要注意的,redis 所有的key都会放在内存中,在内存不够时,只把value 值放入交换区虽使用虚拟内存,但性能基本不受影响,需要注意的是要把vm-max-memory设置到足够来放下所有的key2. vm-swap-file /tmp/redis.swap设置虚拟内存的交换文件路径,不可多个Redis实例共享3. vm-max-memory 0设置开启虚拟内存后,redis将使用的最大物理内存大小。默认为0,redis将把他所有能放到交换文件的都放到交换文件中,以尽量少的使用物理内存即当vm-max-memory设置为0的时候,其实是所有value都存在于磁盘在生产环境下,需要根据实际情况设置该值,最好不要使用默认的 0 4. vm-page-size 32设置虚拟内存的页大小如果 value 值比较大,如要在 value 中放置博客、新闻之类的所有文章内容,就设大一点5. vm-pages 134217728设置交换文件的总的

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 行业资料 > 其它行业文档

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号