一,下载redis
http://code.google.com/p/redis/downloads/list
二,解压安装
1,下载后解压 tar zxvf redis-2.6.13.tar.gz 到任意目录,例如/usr/local/redis-2.6.13
解压后,进入redis目录
cd /usr/local/redis-2.6.13
make (编译)
2,拷贝文件
cp redis.conf /etc/ 这个文件时redis启动的配置文件(在redis-2.6.13目录)
cp redis-benchmark redis-cli redis-server /usr/bin/ #这个倒是很有用,这样就不用再执行时加上./了,而且可以在任何地方执行(在redis-2.6.13/src 目录下)
3,设置内存分配策略(可选,根据服务器的实际情况进行设置)
/proc/sys/vm/overcommit_memory
可选值:0、1、2。
0, 表示内核将检查是否有足够的可用内存供应用进程使用;如果有足够的可用内存,内存申请允许;否则,内存申请失败,并把错误返回给应用进程。
1, 表示内核允许分配所有的物理内存,而不管当前的内存状态如何。
2, 表示内核允许分配超过所有物理内存和交换空间总和的内存
值得注意的一点是,redis在dump数据的时候,会fork出一个子进程,理论上child进程所占用的内存和parent是一样的,比如parent占用的内存为8G,这个时候也要同样分配8G的内存给child,如果内存无法负担,往往会造成redis服务器的down机或者IO负载过高,效率下降。所以这里比较优化的内存分配策略应该设置为 1(表示内核允许分配所有的物理内存,而不管当前的内存状态如何)
开启redis端口,修改防火墙配置文件
vi /etc/sysconfig/iptables
加入端口配置
-A RH-Firewall-1-INPUT -m state --state NEW -m tcp -p tcp --dport 6379 -j ACCEPT
重新加载规则
service iptables restart
三, 启动redis服务
redis-server /etc/redis.conf
查看进程,确认redis已经启动
[root@localhost bin]# ps -ef|grep redis
root 17543 14738 0 15:14 pts/3 00:00:00 redis-server /etc/redis.conf
root 17560 14738 0 15:15 pts/3 00:00:00 grep redis
如果这里启动redis服务失败,一般情况下是因为redis.conf文件有问题,建议检查或找个可用的配置文件进行覆盖,避免少走弯路,这里建议,修改redis.conf,设置redis进程为后台守护进程
# By default Redis does not run as a daemon. Use 'yes' if you need it.
# Note that Redis will write a pid file in /var/run/redis.pid when daemonized.
daemonize yes
四 ,测试redis
[root@localhost bin]# redis-cli
redis> set name songbin
OK
redis> get name
"songbin"
五:关闭redis服务
redis-cli shutdown
redis服务关闭后,缓存数据会自动dump到硬盘上,硬盘地址为redis.conf中的配置项dbfilename dump.rdb所设定
强制备份数据到磁盘,使用如下命令
redis-cli save 或者 redis-cli -p 6380 save(指定端口)