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中存储的数据 ...
随机推荐
- 您的 PHP 似乎没有安装运行 WordPress 所必需的 MySQL 扩展”处理方法
转自:http://www.xuebuyuan.com/1549022.html 这已经是一个老掉牙的问题了,部分人使用自己的服务器安装WordPress程序之后,会出现“您的 PHP 似乎没有安装运 ...
- ASSM 的三级位图结构
自动段空间管理(ASSM),它首次出现在Oracle920里(在920以前,段空间的管理方式叫做MSSM,它是由连接列表freelist来完成的,因为freelist存在串行的问题,因此容易引起段头的 ...
- 第十八篇:在SOUI中实现PreTranslateMessage
在MFC中,通常可以通过重载CWnd::PreTranslateMessage这样一个虚函数来实现对一些窗口消息的预处理.多用于tooltip的显示控制. 在SOUI中也实现了类似的机制. 要在SOU ...
- 银行管理系统[C++]
//项目:银行管理系统 //系统实现的主要有管理,取款机管理,用户查询等功能: //*管理模块:存款.取款.开户.销户.修改信息.办卡.挂失卡; //*用户查询模块; //*取款机信息管理模块:管理员 ...
- 接口JSon字符串格式
- Strust2 初体验
Struts2的第一个案例 首先我们需要引入架包 entity: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 package ...
- SQLServer两张表筛选相同数据和不同数据
概述 项目中经常会对两张数据库表的数据进行比较,选出相同的数据或者不同的数据.在SQL SERVER 2000中只能用Exists来判断,到了SQL SERVER 2005以后可以采用EXCEPT和I ...
- MySQL的批处理
MySQL默认是关闭批处理的,所以我们在默认状态下(批处理未打开)向数据库中存入10000条数据,核心代码如下: package cn.itcast.demo5; import java.sql.Co ...
- 【前台页面 BUG】回车按钮后,页面自动跳转
点击回车按钮后,页面自动的迅速跳转 原因: 表单隐式提交了. 解决方法: 在方法执行完成后,加上return false; 代码如下: /** * 注册按钮的点击事件 */ $("#regi ...
- ERROR Shell: Failed to locate the winutils binary in the hadoop binary path
文章发自:http://www.cnblogs.com/hark0623/p/4170172.html 转发请注明 14/12/17 19:18:53 ERROR Shell: Failed to ...