`
hanqunfeng
  • 浏览: 1526274 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

linux下redis的安装

阅读更多

以Red Hat Enterprise Linux 5为例进行讲解。

 

相关系列:

linux下jdk的安装

linux下ant的安装

linux下redis的安装

linux下svn的安装

linux下nginx的安装

linux下graphviz的安装

linux下doxygen的安装

 

 

 

安装redis版本为1.2.6

 

一。下载redis

下载地址:http://code.google.com/p/redis/downloads/list

选择redis-1.2.6.tar.gz  将该下载包拷贝到/usr/local/redis下(随意了,找个地方就好)

 

二。安装

cd /usr/local/redis

tar zxvf redis-redis-1.2.6.tar.gz
cd redis-redis-1.2.6
make

 

由于没有make install,所以得把源代码目录里的关键文件手动复制到适当的位置:

cp redis.conf /etc/ #看到一些资料都是这么做的,搞不懂为什么一定要放到那里

cp redis-benchmark redis-cli redis-server /usr/bin/ #这个倒是很有用,这样就不用再执行时加上./了,而且可以在任何地方执行

 

如果内存情况比较紧张的话,需要设定内核参数:

      echo 1 > /proc/sys/vm/overcommit_memory

这里说一下这个配置的含义:

/proc/sys/vm/overcommit_memory
该文件指定了内核针对内存分配的策略,其值可以是0、1、2。
0, 表示内核将检查是否有足够的可用内存供应用进程使用;如果有足够的可用内存,内存申请允许;否则,内存申请失败,并把错误返回给应用进程。
1, 表示内核允许分配所有的物理内存,而不管当前的内存状态如何。
2, 表示内核允许分配超过所有物理内存和交换空间总和的内存

 

然后编辑redis.conf配置文件(/etc/redis.conf),按需求做出适当调整,比如:

daemonize yes #转为守护进程,否则启动时会每隔5秒输出一行监控信息
save 60 1000 #减小改变次数,其实这个可以根据情况进行指定
maxmemory 256000000 #分配256M内存

 

最后还要开放redis的端口,否则客户端无法连接。方法如下:

vi /etc/sysconfig/iptables #需要具备其修改权限

 

增加一行:

# redis
-A RH-Firewall-1-INPUT -m state --state NEW -m tcp -p tcp --dport 6379 -j ACCEPT

 

保存后重启iptables:

service iptables restart (PATH中加入了/sbin/)或者 /etc/init.d/iptables restart
 

 

三。验证

1.启动服务:

redis-server /etc/redis.conf

[wap@hanqunfeng redis-1.2.6]$ redis-server /etc/redis.conf 
New pid: 12776

查看是否redis已经启动:

[wap@hanqunfeng redis-1.2.6]$ ps -ef | grep redis
wap      12776     1  0 15:15 ?        00:00:00 redis-server /etc/redis.conf
wap      12782 12751  0 15:17 pts/2    00:00:00 grep redis

 

 2.存取值

[wap@hanqunfeng redis-1.2.6]$ redis-cli set name value
OK
[wap@hanqunfeng redis-1.2.6]$ redis-cli get name
value

 

3.关闭服务

[wap@hanqunfeng redis-1.2.6]$ redis-cli shutdown

 如果端口变化可以指定端口: redis-cli -p 6380 shutdown

 

这时内存中的数据会自动写入到硬盘,文件地址是在redis.conf里配置的:

dbfilename dump.rdb

 

说明:数据备份可以通过定期备份该文件实现。

 

另外,从网上看到说redis不能将内存数据转存到硬盘上,这个问题我也遇到了,后来发现是用户权限的问题,最开始启动redis我使用的root用户,后来使用wap用户就发现不能将数据写入硬盘,这是因为dump.rdb已经是root权限了,不知道说redis不能存储到硬盘的人是不是和我犯了同样的错误。

 

另外,我发现执行redis-benchmark命令时也会将内存数据写入硬盘。

redis-benchmark:检查当前机器的处理性能。

 

4.重启服务后再次取值,取值成功

[wap@hanqunfeng redis-1.2.6]$ 
[wap@hanqunfeng redis-1.2.6]$ redis-server /etc/redis.conf 
New pid: 12797
[wap@hanqunfeng redis-1.2.6]$ redis-cli get name
value

 

5.强制保存内存数据到硬盘

因为redis是异步写入磁盘的,如果要让内存中的数据马上写入硬盘可以执行如下命令:

redis-cli save 或者 redis-cli -p 6380 save(指定端口)

 

注意,以上部署操作需要具备一定的权限,比如复制和设定内核参数等。

 

ok,redis配置完成。

 

 

分享到:
评论
2 楼 J-catTeam 2010-12-05  
不错,不过现在缺乏一些相关实际运用时的环境数据。
1 楼 rails2007 2010-07-12  
很详细,步步到位,不错!

相关推荐

Global site tag (gtag.js) - Google Analytics