redis-cluster集群安装(redis-3.2.8.jar)

来源:互联网 发布:手机编辑epub软件 编辑:程序博客网 时间:2024/06/10 20:01

Redis集群搭建

为了保证可以进行投票,需要至少3个主节点。

每个主节点都需要至少一个从节点,所以需要至少3个从节点

一共需要6台redis服务器

可以使用6个redis实例

6个redis实例的端口号,7001~7006

 

1.1.1. 准备redis集群的安装环境

redis集群的管理工具使用的是ruby脚本语言,安装集群需要ruby环境。

 

使用redis-cluster需要部署环境

1. 安装ruby环境

2. 安装Ruby的打包系统

3. 安装redis的ruby接口库

 

 

首先查看系统有无ruby环境及打包系统,有些系统自带了ruby环境及打包系统

[root@localhost ~]# rpm -qa | grep ruby

                       

安装ruby环境

[root@itcast-01 redis-cluster]# yum install ruby

安装Ruby的打包系统

[root@itcast-01 redis-cluster]# yum install rubygems

 

至于redis的ruby接口是本身系统不会自带需要自己安装的,

请注意,该文档使用的是redis-3.2.8.jar

最好使用redis-3.2.1.gem,否则在设置集群节点主从操作时会有waring报警,

是由于redis.jar与ruby版本原因,接口有冲突

 

安装redis的ruby接口库,请使用redis-3.2.1.gem

 

先上传,再执行命令安装

[root@itcast-01 ~]# gem install redis-3.2.1.gem

 

 

测试一下irb命令是否好用在命令行输入irb如果出来如下那说明安装成功然后在输入puts "Hello Ruby"

就能开始你的ruby之路了,如果你想退出ruby交换模式可以使用ctrl + d

 

 

 

1.1.2. 准备6个redis实例

上传redis-3.2.8.jar,并解压

在Linux的CRT客户端,按alt+p进行上传,可以直接把安装包拖动上去

       [root@localhost bin] tar –zxvf  redis-3.2.8.jar.gz

 

1.1.3执行安装

进入解压的文件夹,进行编译

[root@itcast-01 ~]# cd redis-3.2.8

 

执行安装,指定安装路径. PREFIX需要大写

[root@itcast-01 redis-3.2.8]# make install PREFIX=/usr/local/redis

成功效果:

 

      1.1.4查看安装目录

进入目录

[root@itcast-01 redis-3.2.8]# cd /usr/local/redis/bin/

 

常用的是客户端和服务端

redis-cli 是客户端

redis-server 是服务端

 

从安装包中复制redis.conf文件到/usr/local/redis/bin中

[root@itcast-01 bin]# cp /usr/local/bin/redis-3.2.8/redis.conf ./

 

 

      1.1.5准备6个redis实例

1. 创建文件夹redis-cluster

2. 把bin复制6份到redis-clsuter

[root@localhost bin]# cd ..

[root@localhost redis]# cp -r bin redis-cluster/redis1

[root@localhost redis]# cp -r bin redis-cluster/redis2

[root@localhost redis]# cp -r bin redis-cluster/redis3

[root@localhost redis]# cp -r bin redis-cluster/redis4

[root@localhost redis]# cp -r bin redis-cluster/redis5

[root@localhost redis]# cp -r bin redis-cluster/redis6

 

 

3. 依次修改redis.conf配置文件 4个地方修改

[root@localhost redis01]# vim redis.conf

 

bind 127.0.0.1
# 绑定的主机地址,不设置默认将处理所有请求

这里是设置的是默认处理所有请求

 

protected-mode yes
# 是否开启保护模式,默认开启,要是配置里面没有指定bind和密码,开启该参数后,redis只会本地进行访问,
拒绝外部访问,要是开启了密码和bind,可以开启,否则最好关闭,设置为no

这里设置的不开启保护,允许外部访问

 

port 6379
# 监听的端口号

依次修改端口号为7001~7006

 

daemonize yes
# 是否以守护进程的模式运行,当使用启动脚本运行时,与此设置关系不大

这里设置的允许后台运行

 

4. 启动6个redis实例

编写脚本实现

1. 编写脚本

[root@localhost redis-cluster]# vim start-all.sh

cd redis1

./redis-server redis.conf

cd ..

cd redis2

./redis-server redis.conf

cd ..

cd redis3

./redis-server redis.conf

cd ..

cd redis4

./redis-server redis.conf

cd ..

cd redis5

./redis-server redis.conf

cd ..

cd redis6

./redis-server redis.conf

cd ..

 

2. 设置脚本启动权限

[root@localhost redis-cluster]# chmod u+x start-all.sh

 

 

3. 执行脚本

[root@localhost redis-cluster]# ./start-all.sh

[root@localhost redis-cluster]# ps -ef | grep redis

效果

 

 

集群管理工具在redis解压文件夹的src的文件夹中

使用redis-cluster的集群管理工具启动集群

 

 

先进入集群管理工具所在的路径

[root@localhost redis-cluster]# cd /usr/local/bin/redis-3.2.8/src/

再启动命令(注意修改为自己的ip最好不用127.0.0.1和port)

[root@localhost src]# ./redis-trib.rb create --replicas 1 192.168.2.236:7001 192.168.2.236:7002 192.168.2.236:7003 192.168.2.236:7004 192.168.2.236:7005 192.168.2.236:7006

 

 

启动信息

>>> Performing hash slots allocation on 6 nodes...

Using 3 masters:

192.168.2.236:7001

192.168.2.236:7002

192.168.2.236:7003

Adding replica 192.168.37.131:7004 to 192.168.2.236:7001

Adding replica 192.168.37.131:7005 to 192.168.2.236:7002

Adding replica 192.168.37.131:7006 to 192.168.2.236:7003

M: 955567f988830cdf4328854f815719ea28082ca8 192.168.2.236:7001

   slots:0-5460 (5461 slots) master

M: 4f3eeced04b930aa48193699301745a05a70697a 192.168.2.236:7002

   slots:5461-10922 (5462 slots) master

M: 871a684dbbc0f43dcc16107710d7bd2f4e6de76a 192.168.2.236:7003

   slots:10923-16383 (5461 slots) master

S: baca3ce2223dfcd9c636a7193b12998b1dbb2431 192.168.2.236:7004

   replicates 955567f988830cdf4328854f815719ea28082ca8

S: 0b599863ddf2e03b0326c75b874a1af8ae430d2e 192.168.2.236:7005

   replicates 4f3eeced04b930aa48193699301745a05a70697a

S: 92f712d954c62f2743e2e572f6582a6ef9a163e0 192.168.2.236:7006

   replicates 871a684dbbc0f43dcc16107710d7bd2f4e6de76a

Can I set the above configuration? (type 'yes' to accept): yes

>>> Nodes configuration updated

>>> Assign a different config epoch to each node

>>> Sending CLUSTER MEET messages to join the cluster

Waiting for the cluster to join..

>>> Performing Cluster Check (using node 192.168.2.236:7001)

M: 955567f988830cdf4328854f815719ea28082ca8 192.168.2.236:7001

   slots:0-5460 (5461 slots) master

M: 4f3eeced04b930aa48193699301745a05a70697a 192.168.2.236:7002

   slots:5461-10922 (5462 slots) master

M: 871a684dbbc0f43dcc16107710d7bd2f4e6de76a 192.168.2.236:7003

   slots:10923-16383 (5461 slots) master

M: baca3ce2223dfcd9c636a7193b12998b1dbb2431 192.168.2.236:7004

   slots: (0 slots) master

   replicates 955567f988830cdf4328854f815719ea28082ca8

M: 0b599863ddf2e03b0326c75b874a1af8ae430d2e 192.168.2.236:7005

   slots: (0 slots) master

   replicates 4f3eeced04b930aa48193699301745a05a70697a

M: 92f712d954c62f2743e2e572f6582a6ef9a163e0 192.168.2.236:7006

   slots: (0 slots) master

   replicates 871a684dbbc0f43dcc16107710d7bd2f4e6de76a

[OK] All nodes agree about slots configuration.

>>> Check for open slots...

>>> Check slots coverage...

[OK] All 16384 slots covered.

1.2. redis集群连接

想要外部链接linux redis-cluster需要对防火墙进行设置

vi/etc/sysconfig/iptables #编辑防火墙配置文件

:wq! #保存退出

备注:这里使用700到7006端口为例。***部分一般添加到“-A INPUT -p tcp -m state --state NEW -m tcp--dport 22 -j ACCEPT”行的上面或者下面,切记不要添加到最后一行,否则防火墙重启后不生效。

 

 

 

Systemctl restart iptables.service #最后重启防火墙使配置生效

 

 

1.2.1. 使用redis命令行客户端连接

[root@localhost bin]# ./redis-cli -h 192.168.2.236 -p 7006 -c

192.168.37.131:7006> set hello money

-> Redirected to slot [866] located at 192.168.2.236:7001

OK

 

一定要加-c参数,节点之间就可以互相跳转

 

1.2.2. redis的java客户端连接(Jedis)

使用的是JedisCluster类进行连接

public class JedisClusterTest {

 

    public static void main(String[] args) {

       // 1. 创建JedisCluster对象

       // 设置节点信息,放到set中

       Set<HostAndPort> nodes = new HashSet<>();

       nodes.add(new HostAndPort("192.168.2.236", 7001));

       nodes.add(new HostAndPort("192.168.2.236", 7002));

       nodes.add(new HostAndPort("192.168.2.236", 7003));

       nodes.add(new HostAndPort("192.168.2.236", 7004));

       nodes.add(new HostAndPort("192.168.2.236", 7005));

       nodes.add(new HostAndPort("192.168.2.236", 7006));

 

       // 创建对象

       JedisCluster jedisCluster = new JedisCluster(nodes);

 

       // 2. 使用jedisCluster操作redis,方法和jedis是一样的

       String key = "jedisCluster";

       String setResult = jedisCluster.set(key, "Hello redis !");

       String getResult = jedisCluster.get(key);

 

       System.out.println(setResult + ":" + getResult);

 

       // 3. 关闭jedisCluster连接(在程序执行完之后,才能关闭,他的内部已经封装了连接池)

       jedisCluster.close();

 

    }

 

}