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中存储的数据 ...
随机推荐
- 等号赋值与memcpy的效率问题
转自:http://www.aiuxian.com/article/p-1309055.html 偶尔看到一个说法,说,小内存的拷贝,使用等号直接赋值比memcpy快得多.结合自己搜集到的资料,整理成 ...
- Android开发的教程和资源
Android 设计指南非官方简体中文版 http://www.apkbus.com/design/index.html NDK下载 http://developer.android.com/tool ...
- WEB前端知识体系脑图
说在开始的话: 我上大学那会,虽说主要是学Java语言,但是web前端也稍微学了一些,那时候对前端也没多在意,因为涉入的不深,可以搞一个差不多可以看的界面就可以了,其他也没过多在意. 因为稍微了解一点 ...
- 汇编学习(四)——算术运算程序
(一)跳转指令 一.无条件跳转指令(不管标志寄存器,执行到这句直接跳转) 1.段内直接跳转指令 (1)指令格式: JMP SHORT short_label; IP<--IP+DB,即代码直接跳 ...
- PHP 一个表单多个提交按钮,处理不同的业务逻辑
<?phpini_set("error_reporting","E_ALL & ~E_NOTICE");?> <head>< ...
- three.js入门2
新建一个html文件 <!DOCTYPE html> <html> <head> <title></title> <style> ...
- jQuery入门第一天
使用jQuery之前,我们需要加一些代码到HTML文件中. 首先在页面顶端增加一行script元素,然后写上结束符. 浏览器会运行script 里所有的Javascript,包括jQuery. 在你的 ...
- HDU5461 Largest Point(暴力)
这题第一眼就想到暴力.. 枚举每一个ti,就能确定tj,tj一定是剩下数最大或最小的.为了求tj就要求出数列最大最小次大次小.时间复杂度O(n). 感觉暴力挺有趣的. #include<cstd ...
- CSS中文字体对照表
http://hotoo.googlecode.com/svn/trunk/labs/css/css-fonts.html CSS中文字体对照表 css字体名可以使用2种Unicode格式,以“微软雅 ...
- 【SAP BO】【WEBI】【转】Webi实现动态选择度量
我们都知道Web Intelligence具有高级的分析功能,是一个非常灵活的报表工具.在这篇文章里,我会演示一个使用Webi实现动态选择度量对象的方案.首先解释一下什么是”动态选择度量”:例如我们有 ...