Redis入门笔记(二)-配置及运行
转自: http://gly199.iteye.com/blog/1056424
1、redis基本参数
redis的配置文件中的常见参数如下:
daemonize | 是否以后台进程运行,默认为no,一般需要改为yes |
pidfile | 如以后台进程运行,则需指定一个pid,默认为/var/run/redis.pid |
bind | 绑定主机IP,默认值为127.0.0.1 |
port | 监听端口,默认为6379 |
timeout | 超时时间,默认为300(秒),由于应用中使用了连接池,所以这里建议设置为0,表示无限制 |
loglevel | 日志记录等级,有4个可选值,debug,verbose(默认值),notice,warning |
logfile | 日志文件 |
databases | 可用数据库数,默认值为16,默认数据库为0 |
save <seconds> <changes> | 指出在多长时间内,有多少次更新操作,就将数据同步到数据文件。这个可以多个条件配合,比如默认配置文件中的设置,就设置了三个条件,如果不希望使用snapshot方式,把所有的save配置全部注释掉即可 |
save 900 1 | 900秒(15分钟)内至少有1个key被改变 |
rdbcompression | 存储至本地数据库时是否压缩数据,默认为yes |
dbfilename | 默认值为dump.rdb |
dir | 本地数据库存放路径,默认值为 ./ |
slaveof <masterip> <masterport> | 当本机为从服务时,设置主服务的IP及端口(注释) |
requirepass | 连接密码(注释) |
maxclients | 最大客户端连接数,默认不限制(注释) |
maxmemory <bytes> | 设置最大内存,达到最大内存设置后,Redis会先尝试清除已到期或即将到期的Key,当此方法处理后,任到达最大内存设置,将无法再进行写入操作。(注释) |
appendonly | 是否在每次更新操作后进行日志记录,如果不开启,可能会在断电时导致一段时间内的数据丢失。因为redis本身同步数据文件是按上面save条件来同步的,所以有的数据会在一段时间内只存在于内存中。默认值为no |
appendfilename | 更新日志文件名,默认值为appendonly.aof(注释) |
appendfsync | 更新日志条件,共有3个可选值。no表示等操作系统进行数据缓存同步到磁盘,always表示每次更新操作后手动调用fsync()将数据写到磁盘,everysec表示每秒同步一次(默认值) |
vm-enabled | 是否使用虚拟内存,默认值为no,强烈不建议开启 |
vm-swap-file | 虚拟内存文件路径,默认值为/tmp/redis.swap,不可多个Redis实例共享 |
vm-max-memory | 将所有大于vm-max-memory的数据存入虚拟内存,无论vm-max-memory设置多小,所有索引数据都是内存存储的(Redis的索引数据 就是keys),也就是说,当vm-max-memory设置为0的时候,其实是所有value都存在于磁盘。默认值为0 |
几个值得注意的参数:
1、daemonize 是否在后台运行,这里我们要设置为yes,表示在后台运行,否则ctrl+c服务就停了
2、port 我们设置为自己想要的就可以,多个实例需要设置多个配置文件
3、timeout 如果应用中使用了连接池,最好设置为0,表示不使用服务器自动断开的功能,否则容易出现java.net.SocketTimeoutException: Read timed out 或者是 It seems like server has closed the connection 这样的异常,当然应用中千万要控制住连接数,打开的连接需要记得关闭
4、save 900 1 这种snapshot建议放到从库操作,需要注意的是这个snapshot是以fork一个进程的形式,然后在子进程里dump内存的,如果主进程还在进行写操作的话,最坏情况下需要占用一倍的空间,比如主进程用了15G空间,那么在fork的时候就有可能需要30G的空间来dump内存,所以预留内存是非常重要的,在一台机器上运行多个实例使每个实例所占用的内存尽量少也是一个解决办法(其实不dump的话,我还没见redis服务器挂过...除非硬盘挂掉...咱们不还有从库么,哈哈)
5、maxmemory 这个可以根据服务器硬件来设置,怎么说呢,还是值得设置一下的,对内存的监控是redis运维的最重要的部分
6、VM相关功能,坚决关闭即可,那玩意连作者自己都知道写的渣
7、AOF,没用过,不评价
2、多端口运行的配置
redis是单进程的,所以咱得根据CPU的数目,确定究竟该运行几个实例,这样才能最好的发挥性能优势,比如服务器是8core的,那最好能够运行8个以上的实例,这里只以第一个作为举例
1、假设redis的安装目录在/home/app/redis/下面,即这个目录下包含了redis-benchmark/redis-cli/redis-server这几个可执行文件,现在在下面新建一个servers的文件夹,存放所有的实例
mkdir -p /home/app/redis/servers/0/
mkdir -p /home/app/redis/servers/0/conf
mkdir -p /home/app/redis/servers/0/data
mkdir -p /home/app/redis/servers/0/run
mkdir -p /home/app/redis/servers/0/logs
2、然后我们需要拷贝一份配置文件到该实例的路径下
cp redis.conf /home/app/redis/servers/0/conf
3、修改配置文件中的下列内容
pidfile /home/app/redis/servers/0/run/redis.pid
port 10379
logfile /home/app/redis/servers/0/logs/stdout.log
dbfilename /home/app/redis/servers/0/data/dump.rdb
3、redis启动
配置好了之后可以启动了,还是以刚才的路径为例
./redis-server /home/app/redis/servers/0/conf/redis.conf
4、redis停止
停止redis的命令如下
./redis-cli -p 10379 shutdown
Redis入门笔记(二)-配置及运行的更多相关文章
- redis入门笔记(1)
redis入门笔记(1) 1. Redis 简介 •Redis是一款开源的.高性能的键-值存储(key-value store).它常被称作是一款数据结构服务器(data structure serv ...
- redis入门笔记
redis入门笔记 参考redis实战手册 1. Redis在windows下安装 下载地址:https://github.com/MSOpenTech/redis/tags 安装Redis 1.1. ...
- redis入门笔记(2)
redis入门笔记(2) 上篇文章介绍了redis的基本情况和支持的数据类型,本篇文章将介绍redis持久化.主从复制.简单的事务支持及发布订阅功能. 持久化 •redis是一个支持持久化的内存数据库 ...
- Redis学习笔记二 (BitMap算法分析与BitCount语法)
Redis学习笔记二 一.BitMap是什么 就是通过一个bit位来表示某个元素对应的值或者状态,其中的key就是对应元素本身.我们知道8个bit可以组成一个Byte,所以bitmap本身会极大的节省 ...
- redis相关笔记(二.集群配置及使用)
redis笔记一 redis笔记二 redis笔记三 1.配置:在原redis-sentinel文件夹中添加{8337,8338,8339,8340}文件夹,且复制原8333中的配置 在上述8333配 ...
- Redis学习笔记4-Redis配置详解
在Redis中直接启动redis-server服务时, 采用的是默认的配置文件.采用redis-server xxx.conf 这样的方式可以按照指定的配置文件来运行Redis服务.按照本Redi ...
- Redis入门及主从配置
1.Redis入门简介 Redis是一个开源的使用ANSI C语音编写.支持网络.可基于内存亦可持久化的日志型,Key-Value数据库.支持存储的value类型包括 string(字符串).list ...
- Redis学习笔记4-Redis配置具体解释
在Redis中直接启动redis-server服务时, 採用的是默认的配置文件.採用redis-server xxx.conf 这种方式能够依照指定的配置文件来执行Redis服务. 依照本Redi ...
- NoSQL之Redis入门笔记
Redis 1.Redis介绍 1.1 NoSQL:一类新出现的数据库(not only sql),它的特点 不支持sql语法 存储结构跟传统关系型数据库中的那种关系表完全不同,nosql中存储的数据 ...
随机推荐
- C语言中main函数的参数
转自:http://blog.csdn.net/cnctloveyu/article/details/3905720 我们经常用的main函数都是不带参数的.因此main 后的括号都是空括号.实际上, ...
- 在Virtulbox上装Ubuntu
做个程序员,会用Linux,这应该是最基本的要求吧.可惜本人经常用Windows,只是偶尔去服务器上做些操作的时候才接触到linux.so,我要学Linux.刚学所以还是先装个虚拟机吧,等在虚拟机上用 ...
- 两个本地(localhost)html文件之间的传值
什么是iframe? iframe 元素会创建包含另外一个文档的内联框架(即行内框架).可以理解为把iframe解释成“浏览器中的浏览器“ 在IE中: document.frames[i].docum ...
- jQuery基础知识点(DOM操作)
1.样式属性操作 1)设置样式属性操作 ①设置单个样式: // 第一个参数表示:样式属性名称 // 第二个参数表示:样式属性值 $(selector).css(“color”, ...
- cocos2dx游戏开发——别踩白块学习笔记(二)——经典模式的实现
一.创建GameScene以及GameLayer 就是简单创建一个Scene而已,在此就不多说啦~,可以参照我的打飞机的学习笔记(2). 二.添加一个开始栏 很简单,就是调用Block中的create ...
- 【T_SQL】 基础
一.T-SQL 的组成 1.DML(数据操作语言 Data Manipulation Language) 查询.插入.删除和修改数据库中的数据.SELECT.INSERT. ...
- 【转】fastdb中的数据字典
在程序的启动过程中,第一项任务,在没执行main 函数之前,通过REGISTER宏定义,把表的结构存储在一个全局变量的列表中static dbTableDescriptor* chain,由于此时数据 ...
- Spring进阶—如何用Java代码实现邮件发送(二)
http://www.cnblogs.com/itsource/p/4266905.html
- 线段树(区间操作) POJ 3325 Help with Intervals
题目传送门 题意:四种集合的操作,对应区间的01,问最后存在集合存在的区间. 分析:U T [l, r]填充1; I T [0, l), (r, N]填充0; D T [l, r]填充0; C T[0 ...
- 【转载】LoadRunner11下载以及详细破解说明
前期准备:LoadRunner11 下载请猛戳这里 传送门LoadRunner破解文件 下载请猛戳这里 传送门LoadRunner注册表清理工具 下载请猛戳这里 传送门 LoadRunner11破解方 ...