redis集群

Posted wolf12

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了redis集群相关的知识,希望对你有一定的参考价值。

cd /root/software

wget http://download.redis.io/releases/redis-3.2.4.tar.gz

tar -zxvf redis-3.2.4.tar.gz 

cd redis-3.2.4

make && make install

cd src
cp redis-trib.rb /usr/local/bin/ 
mkdir redis_cluster 
 
mkdir 7000 7001 7002
cp redis.conf redis_cluster/7000
cp redis.conf redis_cluster/7001
cp redis.conf redis_cluster/7002 

 复制下面到redis-7000.conf  其他的也一样,相应修改端口。IP必须改成192.168.1.1,不可以是127.0.0.1

port  7000                                        //端口7000,7002,7003        
bind 本机ip                                       //默认ip为127.0.0.1 需要改为其他节点机器可访问的ip 否则创建集群时无法访问对应的端口,无法创建集群
daemonize    yes                               //redis后台运行
pidfile  /var/run/redis_7000.pid          //pidfile文件对应7000,7001,7002
cluster-enabled  yes                           //开启集群  把注释#去掉
cluster-config-file  nodes_7000.conf   //集群的配置  配置文件首次启动自动生成 7000,7001,7002
cluster-node-timeout  15000                //请求超时  默认15秒,可自行设置
appendonly  yes                           //aof日志开启  有需要就开启,它会每次写操作都记录一条日志
第一台机器上执行
redis-server redis_cluster/7000/redis.conf
redis-server redis_cluster/7001/redis.conf
redis-server redis_cluster/7002/redis.conf

另外一台机器上执行
redis-server redis_cluster/7003/redis.conf
redis-server redis_cluster/7004/redis.conf
redis-server redis_cluster/7005/redis.conf 

 

集群验证

redis-cli -h 192.168.31.245 -c -p 7002

成功!哈哈!

 

 

这个工具是用 ruby 实现的,所以需要安装 ruby。安装命令如下:

yum -y install ruby ruby-devel rubygems rpm-build

gem install redis

 

创建集群,在创建集群之前,请确认防火墙本机的节点端口是否开放:7000和1700,7001和1700等。集群的原理是,master要和slave的节点要同步数据,所以一定要确认master和slave服务器必须可以通讯。

 

 

 

redis-trib.rb  create  --replicas  1  192.168.126.130:7000 192.168.126.130:7001  192.168.126.130:7002 192.168.126.131:7003  192.168.126.131:7004  192.168.126.131:7005

 

 

 

参考:http://www.cnblogs.com/wuxl360/p/5920330.html

以上是关于redis集群的主要内容,如果未能解决你的问题,请参考以下文章

java怎么从多台redis集群取数据库

我在工作中遇到的redis集群使用

redis集群概念

python连接redis,redis集群

Python3 redis集群连接 (带密码验证)

c#程序怎么调用redis集群