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中存储的数据 ...
随机推荐
- gdb optimized out错误解决
转自:http://blog.csdn.net/cws1214/article/details/12023093 when linux gdb debug, print a variable, suc ...
- WebStorm中将Project分享到GitHub时报“Error Running Git”错误的解决办法
错误信息 Cannot run program "git.exe":CreateProcess error=2,系统找不到指定的文件. 解决办法 从错误信息就可以知道,WebSto ...
- 64位ubuntu下重新编译hadoop2.2流水账
hadoop官方网站中只提供了32位的hadoop-2.2.0.tar.gz,如果要在64位ubuntu下部署hadoop-2.2.0,就需要重新编译源码包,生成64位的部署包.建议以下操作使用roo ...
- .net Session 详解
(一) 描述当用户在 Web 应用程序中导航 ASP.NET 页时,ASP.NET 会话状态使您能够存储和检索用户的值.HTTP 是一种无状态协议.这意味着 Web 服务器会将针对页面的每个 HTTP ...
- Liferay 6.2 改造系列之十三:修改用户编辑页面表单内容
为简化用户编辑,删除无用内容: 在/portal-master/portal-impl/src/portal.properties文件中,有如下配置: # # Input a list of sect ...
- DSP using MATLAB 示例Example3.4
代码: n = [-1:3]; x = [1:5]; % x(n) = {1,2,3,4,5} % * % k = 0:500; w = (pi/500)*k; % [0,pi] axis divid ...
- Xamarin Android教程Android基本知识版本介绍与系统介绍
Xamarin Android教程Android基本知识版本介绍与系统介绍 Xamarin Android教程Android基本知识版本介绍与系统介绍,开发Andriod有时候不像iOS一样轻松,因为 ...
- 20145223《Java程序程序设计》第3周学习总结
20145223 <Java程序设计>第3周学习总结 教材学习内容总结 第四章内容 1.类与对象 如何定义一个包含有几个值域(Field成员)就是需要我们定义一个类(Class),书上给的 ...
- 我的c++学习(6)默认参数和内联函数
默认参数 一般情况下,函数调用时实参个数应与形参相同,但为了更方便地使用函数,C++也允许定义具有默认参数的函数,这种函数调用时实参个数可以与形参不相同.“默认参数”指在定义或声明函数时为形参指定默认 ...
- 获取iframe的元素并进行操作
获取iframe中的document元素有一下集中方法: 1.getElementById()方法和contentWindow属性: window.onload=function(){ /*必须等待页 ...