热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Redis配置文件redis.conf超详细的解析

Redis配置文件redis.conf超详细的解析:推荐(免费):redis教程文章目录一、常用的三十条配置二、Redis的内存淘汰策略2.1为数据设置超时时间2.2采用LRU算法

推荐(免费):redis教程

文章目录

  • 一、常用的三十条配置
  • 二、Redis的内存淘汰策略
    • 2.1 为数据设置超时时间
    • 2.2 采用LRU算法动态将不用的数据删除
  • 三、自定义配置Redis

Linux下做开发要牢记:软件默认安装在/opt下,对于出厂默认设置的配置文件永远不要去直接改动,正确的做法是备份一份后再操作

Redis的配置文件位于Redis安装目录下,文件名为reids.conf,下面介绍常用的三十个配置,文章附带英译版redis.conf文件。

一、常用的三十条配置


前十条配置

  • daemonize no
    Redis默认不是以守护进程的方式运行,可以修改为yes启用守护进程。

  • pidfile /var/run/redis/pid
    当Redis以守护进程方式运行时,Redis默认会把pid写入/var/run/redis.pid文件,可以通过pidfile指定路径。

  • port 6379
    指定Redis的监听端口。

  • bind 127.0.0.1
    Redis绑定的主机地址。

  • timeout 300
    设置当客户端闲置多长时间后关闭连接,如果为0表示关闭该功能。

  • loglevel verbose
    指定日志记录级别,Redis共支持四个级别:debug、verbose(默认)、notice、warning。

  • logfile stdout
    日志记录方式,默认为标准输出,如果配置Redis为守护进程,而这里的日志记录方式为标准输出,则日志会发送给/dev/null

  • databases 16
    设置数据库的数量,默认数量为0,可以使用select 命令在连接上指定数据库id。

  • save
    指定多长时间内,有多少次更新操作,就将数据同步到数据文件,可以多个条件配合。Redis配置文件中提供了3个条件:
    save 900 1; save 300 10 ;save 60 10000

  • rdbcompression yes
    指定存储至本地数据库时是否压缩数据,默认为yes,Redis采用LZF(压缩算法)压缩,如果为了节省cpu时间,可以关闭该选项,但是会导致数据库文件变的巨大。


中间十条配置

  • dbfilename dump.rdb
    指定本地数据库文件名,默认值为dump.rdb

  • dir ./
    指定本地数据库存放目录

  • slaveof
    社会当本机为slav服务时,设置master服务的IP地址及端口,在Redis启动时,会自动从master进行数据同步

  • masterauth
    当master服务设置了密码保护时,slav服务连接master的密码。

  • requirepass foobared
    设置Redis的连接密码,如果配置了连接密码,客户端 在连接Redis时需要通过AUTH

    命令提供密码,默认是关闭的。

  • maxclients 128
    设置同一时间最大客户端连接数,默认无限制,Redis可以同时打开的客户端连接数为Redis进程可以打开的最大文件描述符数。如果设置maxclients 0,表示不做限制,当客户端连接数到达限制时,Redis会关闭新的连接并向客户端返回max number of clients reached错误信息。

  • maxmemory
    指定Redis最大内存限制,Redis在启动时会把数据加载到内存中,达到最大内存后,Redis会先尝试清除已到期或即将到期的Key,当此方法处理后,仍然到达最大内存设置,将无法进行写入操作,但仍然可以进行读取操作。Redis新的vm机制,会把Key存放内存,value存放在swap区。

  • appendonly no
    指定是否在某次更新操作后进行日志记录,Redis在默认情况下是一部的把数据写入磁盘,如果不开启,可能会在断电时导致一段时间内的数据丢失。

  • appendfilename appendonly.aof
    指定更新日志文件名,默认为appendonly.aof。

  • appendsync everysec
    指定更新日志条件,共有三个可选项:
    ①no:表示等操作系统进行数据缓存同步到磁盘(快)、
    ②always:表示每次更新操作系统后手动调用fsync()将数据写到磁盘(慢、安全)、
    ③everysec:表示美妙同步一次(效率折中,为默认值)

最后十个

  • vm-enable no
    指定是否启用虚拟内存机制,默认值为no,VM机制将数据分页存放,由Redis将访问量较少的页即冷数据swap到磁盘上,访问多的页面由磁盘自动换出到内存中。
  • vm-swap-file /tmp/redis.swap
    虚拟内存文件路径,默认值为/tmp/redis.swap,不可多个Redis实例共享。
  • vm-max-memory 0
    将所有大于vm-max-memory的数据存入虚拟内存,无论vm-max-memory设置多小,所有索引数据都是内存存储的(Redis的索引数据 就是keys),也就是说,当vm-max-memory设置为0的时候,其实是所有value都存在于磁盘。默认值为0
  • vm-page-size 32
    Redis swap文件分成了很多的page,一个对象可以保存在多个page上面,但一个page上不能被多个对象共享,vm-page-size是要根据存储的数据大小来设定的,如果存储很多小对象,page大小最好设置为32或者64bytes;如果存储很大大对象,则可以使用更大的page,如果不确定,就使用默认值。
  • vm-pages 134217728
    设置swap文件中的page数量,由于页表(一种表示页面空闲或使用的bitmap)是放在内存中的,在磁盘上每8个pages将消耗1byte的内存。
  • vm-max-threads 4
    设置访问swap文件的线程数,不要超过机器的核数,如果设置为0,那么所有对swap文件的操作都是串行的,可能会造成比较长时间的延迟。默认值为4。
  • glueoutputbuf yes
    设置在向客户端应答时,是否把较小的包合并为一个包发送,默认为开启。
  • hash-max-zipmap-entries 64/hash-max-zipmap-value 512
    指定在超过一定的数量或者最大的元素超过某一临界值时,采用一种特殊的哈希算法。
  • activerehashing yes
    指定是否激活重置哈希,默认为开启。
  • include /path/to/local.conf
    指定包含其它的配置文件,可以在同一主机上多个Redis实例之间使用同一份配置文件,而同时各个实例又拥有自己的特定配置文件。

二、Redis的内存淘汰策略

Redis作为优秀的缓存中间件,时常会存储大量的数据,即使采用了集群部署来动态扩容,也应该即时的清理内存,维护系统性能。

2.1 为数据设置超时时间

  • expire key time(以秒为单位)            这是最常用的方式
  • setex(String Key, int seconds, String value)  字符串独有的方式

除了字符串自己独有设置过期时间的方法外,其他方法都需要依赖expire方法来设置时间。
如果没有设置时间,那缓存就是永不过期。
如果设置了过期时间,之后又想让缓存永不过期,使用persist key

2.2 采用LRU算法动态将不用的数据删除

内存管理的一种页面置换算法,对于在内存中但又不用的数据块(内存块)叫做LRU,操作系统会根据哪些数据属于LRU而将其移除内存腾出空间来加载另外的数据。

  1. volatile-lru     设定超时时间的数据中,删除最不常用使用的数据

  2. allkeys-lru     查询所有的key中最不常使用的数据进行删除,这是应用最广泛的策略。

  3. volatile-random   在已经设定了超时的数据中随机删除

  4. allkeys-random   查询所有的key,之后随机删除

  5. volatile-ttl      查询全部设定超时时间的数据,之后排序,将马上要国企的数据进行删除

  6. noeviction      如果设置为该属性,则不会进行删除操作,在内存溢出时报错返回

  7. volatile-lfu      从所有配置了超时时间的键中删除使用频率最少的键

  8. allkeys-lfu      从所有键中删除使用频率最少的键

三、自定义配置Redis

进入对应的安装目录 /usr/local/redis,修改 redis.conf 配置文件。

作为初学者Redis一般需要修改下面三项:

  • daemonize no 修改为 daemonize yes,即改为以守护进程启动。
  • bind 127.0.01 注释掉,即改为允许除本机外的机器访问Redis服务。
  • 使用requirepass 设置密码,即保证服务安全/在极少数情况下不设定密码无法进行远程访问。

Redis采用的是单进程多线程的模式。当redis.conf中选项daemonize设置成yes时,代表开启守护进程模式。在该模式下,redis会在后台运行,并将进程pid号写入至redis.conf选项pidfile设置的文件中,此时redis将一直运行,除非手动kill该进程。但当daemonize选项设置成no时,当前界面将进入redis的命令行界面,exit强制退出或者关闭连接工具(putty,xshell等)都会导致redis进程退出。服务端开发的大部分应用都是采用后台运行的模式。

更多相关学习:redis

以上就是Redis配置文件redis.conf超详细的解析的详细内容,更多请其它相关文章!


推荐阅读
  • 图解redis的持久化存储机制RDB和AOF的原理和优缺点
    本文通过图解的方式介绍了redis的持久化存储机制RDB和AOF的原理和优缺点。RDB是将redis内存中的数据保存为快照文件,恢复速度较快但不支持拉链式快照。AOF是将操作日志保存到磁盘,实时存储数据但恢复速度较慢。文章详细分析了两种机制的优缺点,帮助读者更好地理解redis的持久化存储策略。 ... [详细]
  • 篇首语:本文由编程笔记#小编为大家整理,主要介绍了软件测试知识点之数据库压力测试方法小结相关的知识,希望对你有一定的参考价值。 ... [详细]
  • 一、Hadoop来历Hadoop的思想来源于Google在做搜索引擎的时候出现一个很大的问题就是这么多网页我如何才能以最快的速度来搜索到,由于这个问题Google发明 ... [详细]
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • 本文介绍了Java工具类库Hutool,该工具包封装了对文件、流、加密解密、转码、正则、线程、XML等JDK方法的封装,并提供了各种Util工具类。同时,还介绍了Hutool的组件,包括动态代理、布隆过滤、缓存、定时任务等功能。该工具包可以简化Java代码,提高开发效率。 ... [详细]
  • 本文介绍了在Mac上搭建php环境后无法使用localhost连接mysql的问题,并通过将localhost替换为127.0.0.1或本机IP解决了该问题。文章解释了localhost和127.0.0.1的区别,指出了使用socket方式连接导致连接失败的原因。此外,还提供了相关链接供读者深入了解。 ... [详细]
  • 计算机存储系统的层次结构及其优势
    本文介绍了计算机存储系统的层次结构,包括高速缓存、主存储器和辅助存储器三个层次。通过分层存储数据可以提高程序的执行效率。计算机存储系统的层次结构将各种不同存储容量、存取速度和价格的存储器有机组合成整体,形成可寻址存储空间比主存储器空间大得多的存储整体。由于辅助存储器容量大、价格低,使得整体存储系统的平均价格降低。同时,高速缓存的存取速度可以和CPU的工作速度相匹配,进一步提高程序执行效率。 ... [详细]
  • 本文详细介绍了如何使用MySQL来显示SQL语句的执行时间,并通过MySQL Query Profiler获取CPU和内存使用量以及系统锁和表锁的时间。同时介绍了效能分析的三种方法:瓶颈分析、工作负载分析和基于比率的分析。 ... [详细]
  • WhenIusepythontoapplythepymysqlmoduletoaddafieldtoatableinthemysqldatabase,itdo ... [详细]
  • PDO MySQL
    PDOMySQL如果文章有成千上万篇,该怎样保存?数据保存有多种方式,比如单机文件、单机数据库(SQLite)、网络数据库(MySQL、MariaDB)等等。根据项目来选择,做We ... [详细]
  • RouterOS 5.16软路由安装图解教程
    本文介绍了如何安装RouterOS 5.16软路由系统,包括系统要求、安装步骤和登录方式。同时提供了详细的图解教程,方便读者进行操作。 ... [详细]
  • MySQL语句大全:创建、授权、查询、修改等【MySQL】的使用方法详解
    本文详细介绍了MySQL语句的使用方法,包括创建用户、授权、查询、修改等操作。通过连接MySQL数据库,可以使用命令创建用户,并指定该用户在哪个主机上可以登录。同时,还可以设置用户的登录密码。通过本文,您可以全面了解MySQL语句的使用方法。 ... [详细]
  • 本文介绍了操作系统的定义和功能,包括操作系统的本质、用户界面以及系统调用的分类。同时还介绍了进程和线程的区别,包括进程和线程的定义和作用。 ... [详细]
  • 本文介绍了在使用Laravel和sqlsrv连接到SQL Server 2016时,如何在插入查询中使用输出子句,并返回所需的值。同时讨论了使用CreatedOn字段返回最近创建的行的解决方法以及使用Eloquent模型创建后,值正确插入数据库但没有返回uniqueidentifier字段的问题。最后给出了一个示例代码。 ... [详细]
  • 本文介绍了在rhel5.5操作系统下搭建网关+LAMP+postfix+dhcp的步骤和配置方法。通过配置dhcp自动分配ip、实现外网访问公司网站、内网收发邮件、内网上网以及SNAT转换等功能。详细介绍了安装dhcp和配置相关文件的步骤,并提供了相关的命令和配置示例。 ... [详细]
author-avatar
溪龙2012_753
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有