分布式缓存之Redis
Redis简介
redis是一个开源的、使用C语言编写的、支持网络交互的、可基于内存也可持久化的Key-Value数据库。
redis的官网地址,非常好记,是redis.io。(特意查了一下,域名后缀io属于国家域名,是british Indian Ocean territory,即英属印度洋领地)目前,Vmware在资助着redis项目的开发和维护。
源码部署
[root@host ~]# cd /usr/local/src
[root@host src]# wget http://download.redis.io/releases/redis-3.2.2.tar.gz
[root@host src]# tar zxf redis-3.2.2.tar.gz
[root@host src]# cd redis-3.2.2/
[root@host src]# tar zxf redis-3.2.2.tar.gz
[root@host src]# cd redis-3.2.2
[root@host redis-3.2.2]# make PREFIX=/usr/local/redis install
[root@host redis-3.2.2]# cp utils/redis_init_script /etc/init.d/redis_6379
[root@host redis-3.2.2]# chmod +x /etc/init.d/redis_6379
[root@host redis-3.2.2]# mkdir /etc/redis
[root@host redis-3.2.2]# cp redis.conf /etc/redis/6379.conf
[root@host redis-3.2.2]# /etc/init.d/redis-server start
redis配置详解
daemonize no
默认情况下redis 不是以守护进程的模式运行。
pidfile /var/run/redis.pid
在守护进程模式下,pid进程号文件路径的存储位置
port 6379
监听的端口号,设置为0的话,redis不会对tcp 连接进行监听;
bind 127.0.0.1
绑定本机单一网卡适配器,默认是本机的所有网络适配器
unixsocket /tmp/redis.sock
unixsocketperm 755
默认情况下 redis 是不建立unix socket连接的;
timeout 0
客户端空闲n秒后断开连接; 0 表示不主动断开连接;
tcp-keepalive 0
在linux上,每个一段时间发送 SO_KEEPALIVE ACK的空包;推荐值为60s;
这样做的两点理由:
1、阻止由于某个command执行过长达到timeout超时时间而被断开连接;
2、提高连接错误的检测
(对于长期空闲的tcp连接很容易被NAT、防火墙等直接close掉。这情况下对于client和server在没IO操作下,都是没办感知的。另外,像Server程序或网络(硬件)突然Crash掉,也是同样的情况。)
使用keepalive,内核会定时帮你发送一个空的ACK包,如果连接已断开或网络不可达,就会收到RST。
loglevel notice
记录日志的级别
- debug:包含所有信息,主要用于开发环境中;
- verbose:相比debug 只显示有用信息;
- notice: 生产环境推荐配置
- warning: 只记录重要、错误信息和严重信息;
logfile stdout
日志文件记录位置, 如果采用daemonize 守护进程的模式,且参数值为stdout,那logs会被重定向到/dev/null
syslog-enabled no
将日志信息记录到 syslog 文件中。默认不允许;
syslog-facility local0
(必须是 LOCAL 0 -- LOCAL 7)作为syslog 的日志设备
databases 16
数据库的数量, select dbid ; dbid 取值范围between 0 and 'databases'-1
RDB快照部分:
将内存中的数据刷写到磁盘上save <seconds> <changes> save 900 1 save 300 10 save 60 10000
符合以上条件的就刷新磁盘上:
900秒(15分钟)之后,且至少1次变更
300秒(5分钟)之后,且至少10次变更
60秒之后,且至少10000次变更
(我一直怀疑数据会丢失多少?丢失几秒的?)
不刷写到磁盘上的话,直接 save "" 就可以。
stop-writes-on-bgsave-error yes
默认情况下,如果在RDB snapshots持久化过程中出现问题,设置该参数后,Redis是不允许用户进行任何更新操作(set...)。避免人为强制停止redis 快照,如果采用良好的监控系统,那么可以将该参数设置为 no
可能出现的错误信息:
MISCONF Redis is configured to save RDB snapshots, but is currently not able to persist on disk. Commands that may modify the data set are disabled. Please check Redis logs for details about the error.
rdbcompression yes
在导出.RDB数据库文件的时候采用LZF压缩字符串和对象。想节省一些CPU资源可以设置为no,但数据量可能会很大。
rdbchecksum yes
RDB快照制作过程中会在文件的末尾写入 crc64的校验值。这样可能很好的保证数据的正确性。代价是在 saving 或者 loading RDB file 的时候,性能下降10%(待测试);如果仅用该选项的话,文件末尾的校验值会用0代替,这样在loading data 的时候,会跳过check。
dbfilename dump.rdb
快照文件名dir ./
DB工作目录,必须是目录名,dumpfile存储的位置。