redis服务器配置

配置选项
Redis 服务器提供了一些配置选项(configuration option),通过修改这些选项的值,可以改变选项对应功能的行为。
举个例子,Redis 服务器默认会创建 0 号至 15 号共十六个数据库以供用户使用。
但 Redis 服务器的数据库数量并不是一成不变的,Redis 提供了 databases 选项,它的默认值为 16 ,通过修改这个选项的值,我们可以让服务器创建指定数量的数据库,比如 5 个、10 个、32 个、100 个,诸如此类。
再举一个例子,在介绍 Lua 脚本的时候,我们曾说过,如果一个脚本的运行时间过长,用户可以使用SCRIPT KILL 命令来强制停止脚本,其中 lua-time-limit 选项的值就决定了脚本可以不被打扰地运行的最大毫秒数,如果这个选项的值是 5000 的话,那么只有在脚本运行时间超过 5000 毫秒之后,服务器才会开始接受 SCRIPT KILL 命令,允许用户终结正在运行的脚本。如果有需要的话,用户也可以把这个选项的值调小或者调大。

修改选项的值(1):通过给定参数
Redis 提供了三种方法来修改配置选项的值。
第一种方法是在启动服务器时,通过给定参数的方式来为配置选项设置值,格式为:
$ redis-server --<option1> <value1> --<option2> <value2> --<option3> <value3> ...
比如给定以下参数来启动 Redis 服务器的话,服务器就会创建 32 个数据库:
$ redis-server --databases 32
而给定以下参数可以让服务器创建 100 个数据库,并将服务器的端口设置为 10086:
$ redis-server --databases 100 --port 10086

修改选项的值(2):通过给定配置文件
修改配置选项值的第二种方法是,将要修改的配置选项以及选项的值记录到一个配置文件里面,并在启动服务器时,让服务器载入该配置文件。格式为:
$ redis-server <path-to-config-file>
举个例子,我们可以创建一个包含以下内容的配置文件 redis.conf :
databases 128
port 10086
并在启动服务器时让服务器载入该文件:
$ redis-server redis.conf
那么启动后的服务器将创建 128 个数据库,并使用端口 10086 来监听客户端的连接请求。

修改选项的值(3):使用 CONFIG 系列命令
以上两种方法都只能在服务器启动时修改配置选项的值,通过使用 CONFIG 系列命令,用户可以在服务器运行时动态修改选项的值,也可以通过命令获取选项当前的值,等等。
使用 CONFIG GET 命令可以获取选项当前的值,该命令的格式为:
CONFIG GET <option>
举个例子,执行以下命令可以返回服务器目前设置的 Lua 脚本的最大正常执行时间:
redis> CONFIG GET lua-time-limit
1) "lua-time-limit"
2) "5000"

修改选项的值(3):使用 CONFIG 系列命令
而通过 CONFIG SET 命令则可以修改配置选项的值,该命令的格式为:
CONFIG SET <option> <value>
举个例子,执行以下命令,可以将 Lua 脚本的最大正常执行时间从原来的 5000 改为 3000 :
redis> CONFIG SET lua-time-limit 3000
OK
执行 CONFIG GET 命令可以检查设置是否已经成功:
redis> CONFIG GET lua-time-limit
1) "lua-time

CONFIG SET 的注意事项(1/2)
使用 CONFIG SET 需要注意的一点是, 并不是所有配置选项都可以在服务器运行时动态地设置的,有一些配置选项必须在服务器启动时才能设置。
举个例子,因为创建数据库的工作是在服务器启动时进行的,所以数据库的数量必须在启动服务器时指定,在服务器运行的过程中,尝试使用 CONFIG SET 去修改数据库的数量是不可行的:
redis> CONFIG SET databases 100
(error) ERR Unsupported CONFIG parameter: databases
另一个例子是服务器使用的监听端口号,这个选项也不能在服务器已经运行的情况下设置:
redis> CONFIG SET port 10086
(error) ERR Unsupported CONFIG parameter: port

CONFIG SET 的注意事项(2/2)
CONFIG SET 另外一个需要注意的地方是, CONFIG SET 设置的选项值只会在服务器运行的过程中生效,一旦服务器关机,CONFIG SET 设置的选项值就会丢失。
举个例子, lua-time-limit 选项的默认值为 5000 ,虽然通过 CONFIG SET lua-time-limit 3000 可以将选项的值改为 3000 ,但这个修改只会在服务器的本次运行中有效,一旦服务器关闭并重启的话, luatime-limit 选项的值就会变回默认值 5000 。
redis> CONFIG SET lua-time-limit 3000
OK
redis> CONFIG GET lua-time-limit
1) "lua-time-limit"
2) "3000"
redis> CONFIG GET lua-time-limit # 重启服务器之后执行
1) "lua-time-limit"
2) "5000"

CONFIG REWRITE 命令
如果服务器在启动时载入了配置文件,并且在服务器运行的过程中使用 CONFIG SET 修改了配置选项的值,那么执行 CONFIG REWRITE 命令可以将被修改的配置选项以及它的值写入到配置文件里面。
举个例子,如果服务器启动时载入了包含以下内容的配置文件:
databases 32
lua-time-limit 5000
如果用户在服务器运行的过程中,执行了 CONFIG SET lua-time-limit 3000 命令,并且他打算将这一修改记录到配置文件里面的话,那么他可以执行 CONFIG REWRITE 命令,将配置文件的内容修改为:
databases 32
lua-time-limit 3000
这样服务器在下次启动并载入配置文件时,就会继续将 Lua 脚本的最大正常运行时间设置为 3000 毫秒。

配置选项
三种设置配置选项的方法:
1. 服务器启动时通过参数来设置,格式为 $ redis-server --<option> <value> 。
2. 服务器启动时通过指定配置文件来设置,格式为 $ redis-server <path-to-config-file>
3. 在服务器运行时,通过 CONFIG SET <option> <value> 命令来设置。
需要注意的是,并不是所有配置选项都可以使用 CONFIG SET 来修改,有些选项只能在服务器启动时设置,并且在不使用 CONFIG REWRITE 的情况下, CONFIG SET 设置的选项值在服务器关闭之后就会丢失。
使用 CONFIG GET <option> 命令可以获取配置选项的当前值。如果服务器在启动时载入了配置文件,并且在服务器运行的过程中,用户使用 CONFIG SET 修改了某些选项的值,那么只要使用 CONFIG REWRITE 命令,就可以将 CONFIG SET 的修改记录到配置文件里面,以便服务器下次启动时使用。

时间: 2024-11-07 03:42:49

redis服务器配置的相关文章

Redis服务器的启动过程分析

转载于:http://www.itxuexiwang.com/a/shujukujishu/redis/2016/0216/127.html?1455808771 本文将通过分析代码来介绍Redis的启动过程,通过查看Redis 的启动脚本,得知Redis的启动时从Redis.c的main方法开始的.Redis启动可以分为以下几个步骤: 1.初始化Redis服务器全局配置2.重置服务器Save参数(具体下文详解)和加载配置文件3.初始化服务器4.加载数据库5.开始网络监听 一,初始化Redis服

redis --初级笔记

Redis remote directory server (redis),是一个基于key-value键值对的持久化数据库存储系统,redis支持数据的存储更丰富,包括string,list,setzset等. 这些数据类型都支持push.pop,add,remove及取交集,差集等更丰富的操作,而且这些操作都是原子性的,在此基础上支持不同的排序方式,所有的数据都是保存在内从中的,但是redis的持久化服务还会周期性的吧更新数据写到磁盘以及把修改的操作记录追加到文件里记录下来,比memcach

PHP Redis 集群封装类

<?php /**  * Redis 操作,支持 Master/Slave 的负载集群  *  * @author V哥  */ class RedisCluster{       // 是否使用 M/S 的读写集群方案     private $_iSUSECluster = false;       // Slave 句柄标记     private $_sn = 0;       // 服务器连接句柄     private $_linkHandle = array(         'm

PHP 操作redis 封装的类

1 <?php 2 /** 3 * Redis 操作,支持 Master/Slave 的负载集群 4 * 6 */ 7 class RedisCluster{ 8 9 // 是否使用 M/S 的读写集群方案 10 private $_isUseCluster = false; 11 12 // Slave 句柄标记 13 private $_sn = 0; 14 15 // 服务器连接句柄 16 private $_linkHandle = array( 17 'master'=>null,/

redis安装以及php扩展

redis安装以及php扩展 启动安装:  http://elain.blog.51cto.com/3339379/705846 redis下载:  https://github.com/nicolasff/phpredis/downloads 多台服务安装:   http://www.vquickphp.com/?a=blogview&id=30 开机加自启动: echo "redis-server /etc/redis.conf" >>/etc/rc.local

Yii框架下使用redis做缓存,读写分离

Yii框架中内置好几个缓存类,其中有memcache的类,但是没有redis缓存类,由于项目中需要做主从架构,所以扩展了一下: /** * FileName:RedisCluster * 配置说明 * 配置为1主多从 或者 1个独立的服务器 * 写往主的里面写 * 读是从从的里面读 * 'class'=>'RedisCache', * 'servers'=>array( * array( * 'host'=>'IP1', * 'port'=>'6380', * 'master'=&

Redis从入门到精通:中级篇

原文链接:http://www.cnblogs.com/xrq730/p/8944539.html,转载请注明出处,谢谢 本文目录 上一篇文章以认识Redis为主,写了Redis系列的第一篇,现在开启第二部分的学习,在本文中,我们将看到以下内容: Redis数据结构String.Hash.List.Set.SortedSet及相关操作,提一下Redis在3.2.0之后有新增了一种GEO的数据类型表示地理位置,不过本文这种数据结构略过 Redis其他一些常用命令,分为Key操作与服务器操作 Red

Redis的事务功能详解

Redis的事务功能详解 MULTI.EXEC.DISCARD和WATCH命令是Redis事务功能的基础.Redis事务允许在一次单独的步骤中执行一组命令,并且可以保证如下两个重要事项: >Redis会将一个事务中的所有命令序列化,然后按顺序执行.Redis不可能在一个Redis事务的执行过程中插入执行另一个客户端发出的请求.这样便能保证Redis将这些命令作为一个单独的隔离操作执行. > 在一个Redis事务中,Redis要么执行其中的所有命令,要么什么都不执行.因此,Redis事务能够保证

redis 命令的调用过程

参考文献: Redis 是如何处理命令的(客户端) 我是如何通过添加一条命令学习redis源码的 从零开始写redis客户端(deerlet-redis-client)之路--第一个纠结很久的问题,restore引发的血案 redis命令执行流程分析 通信协议(protocol) Redis主从复制原理 Redis配置文件详解 当用户在redis客户端键入一个命令的时候,客户端会将这个命令发送到服务端.服务端会完成一系列的操作.一个redis命令在服务端大体经历了以下的几个阶段: 读取命令请求