redis集群搭建

1. redis集群原理

在这里插入图片描述

1.2 投票容错

(1)领着投票过程是集群中所有master参与,如果半数以上master节点与master节点通信超过(cluster-node-timeout),认为当前master节点挂掉.
(2):什么时候整个集群不可用(cluster_state:fail)?
a:如果集群任意master挂掉,且当前master没有slave.集群进入fail状态,也可以理解成集群的slot映射[0-16383]不完成时进入fail状态. ps : redis-3.0.0.rc1加入cluster-require-full-coverage参数,默认关闭,打开集群兼容部分失败.
b:如果集群超过半数以上master挂掉,无论是否有slave集群进入fail状态.
ps:当集群不可用时,所有对集群的操作做都不可用,收到((error) CLUSTERDOWN The cluster is down)错误

2 搭建步骤

2.1 准备环境

安装ruby
yum -y install ruby
yum -y install rubygems

2.2 Redis单机版时的数据删除

在这里插入图片描述

2.3 在/usr/local/src下创建目录

在这里插入图片描述

2.4 安装单个redis

2.5 软件上传

2.6 解压

2.7 编译并安装

在这里插入图片描述

2.8 copy 配置到redis的bin目录下

在这里插入图片描述

2.9 修改redis配置文件

1、后台启动
在这里插入图片描述
2、端口号
在这里插入图片描述
3、开启redis集群功能
在这里插入图片描述

2.10 将该redis copy到redis-cluster目录下

在这里插入图片描述

2.11 继续复制5份redis并改名

在这里插入图片描述

2.12 分别修改redis端口号

端口分别为:7002、7003、7004、7005、7006

2.13 编写脚本启动该6个redis服务

1、在redis-cluster目录下创建start-all.sh文件
在这里插入图片描述
2、编辑脚本
在这里插入图片描述

cd /usr/local/src/redis-cluster/7001/bin
./redis-server redis.conf
cd /usr/local/src/redis-cluster/7002/bin
./redis-server redis.conf
cd /usr/local/src/redis-cluster/7003/bin
./redis-server redis.conf
cd /usr/local/src/redis-cluster/7004/bin
./redis-server redis.conf
cd /usr/local/src/redis-cluster/7005/bin
./redis-server redis.conf
cd /usr/local/src/redis-cluster/7006/bin
./redis-server redis.conf                

3、设置脚本的具有可执行权限:chmod u+x start-all.sh
在这里插入图片描述
4、启动脚本:./start-all.sh
在这里插入图片描述

2.14 创建集群—使用ruby脚本

1、将redis解压目录后的src/redis-trib.rb的文件copy到redis-cluster下
在这里插入图片描述
2、执行redis-3.0.0.gem脚本
在这里插入图片描述
3、执行rb脚本
在redis-cluster目录下执行该脚本:
在这里插入图片描述

./redis-trib.rb create --replicas 1 192.168.33.135:7001 192.168.33.135:7002 192.168.33.135:7003 192.168.33.135:7004 192.168.33.135:7005 192.168.33.135:7006

在这里插入图片描述
4、结果
在这里插入图片描述

2.15 测试

在这里插入图片描述

3. Java接口操作Redis集群

	//集群版Jedis
	@Test
	public void testJedisCluster() throws Exception {
		//创建Jedis的连接池配置类
		JedisPoolConfig config = new JedisPoolConfig();
		//设置最大连接数
		config.setMaxTotal(5);
		//设置最大间隔数
		config.setMaxIdle(3);
		
		//节点集
		Set<HostAndPort> hostAndPorts = new HashSet<HostAndPort>();
		//配置多个IP及端口号
		hostAndPorts.add(new HostAndPort("192.168.200.128",6379));
		hostAndPorts.add(new HostAndPort("192.168.200.128",6380));
		hostAndPorts.add(new HostAndPort("192.168.200.128",6381));
		hostAndPorts.add(new HostAndPort("192.168.200.128",6382));
		hostAndPorts.add(new HostAndPort("192.168.200.128",6383));
		hostAndPorts.add(new HostAndPort("192.168.200.128",6384));
		//创建客户端(集群版)
		JedisCluster jedisCluster = new JedisCluster(hostAndPorts,config);
		
		//保存数据
		jedisCluster.set("hejiong", "40");
		//取数据
		String num = jedisCluster.get("hejiong");
		System.out.println(num);
		
		
	}

3.1 Java接口交由Spring进行管理

Redis.xml配置

	<!-- Redis连接池的配置信息 -->
	<bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig"/>
	
	<!-- Redis的集群版Java接口配置交由Spring管理 -->
	<bean id="jedisCluster" class="redis.clients.jedis.JedisCluster">
		<!-- 配置6个IP及端口号到构造器 -->
		<constructor-arg index="0">
			<set>
				<bean class="redis.clients.jedis.HostAndPort">
					<!-- IP -->
					<constructor-arg index="0">
						<value>192.168.200.128</value>
					</constructor-arg>
					<!-- port -->
					<constructor-arg index="1">
						<value>6379</value>
					</constructor-arg>
				</bean>
				<bean class="redis.clients.jedis.HostAndPort">
					<!-- IP -->
					<constructor-arg index="0">
						<value>192.168.200.128</value>
					</constructor-arg>
					<!-- port -->
					<constructor-arg index="1">
						<value>6380</value>
					</constructor-arg>
				</bean>
				<bean class="redis.clients.jedis.HostAndPort">
					<!-- IP -->
					<constructor-arg index="0">
						<value>192.168.200.128</value>
					</constructor-arg>
					<!-- port -->
					<constructor-arg index="1">
						<value>6381</value>
					</constructor-arg>
				</bean>
				<bean class="redis.clients.jedis.HostAndPort">
					<!-- IP -->
					<constructor-arg index="0">
						<value>192.168.200.128</value>
					</constructor-arg>
					<!-- port -->
					<constructor-arg index="1">
						<value>6382</value>
					</constructor-arg>
				</bean>
				<bean class="redis.clients.jedis.HostAndPort">
					<!-- IP -->
					<constructor-arg index="0">
						<value>192.168.200.128</value>
					</constructor-arg>
					<!-- port -->
					<constructor-arg index="1">
						<value>6383</value>
					</constructor-arg>
				</bean>
				<bean class="redis.clients.jedis.HostAndPort">
					<!-- IP -->
					<constructor-arg index="0">
						<value>192.168.200.128</value>
					</constructor-arg>
					<!-- port -->
					<constructor-arg index="1">
						<value>6384</value>
					</constructor-arg>
				</bean>
			</set>
		</constructor-arg>
		<!-- 连接池的配置类 -->
		<constructor-arg index="1" ref="jedisPoolConfig" />
	</bean>

TestJedis测试类中

	//将Redis集群版的Java接口交由Spring管理
	@Autowired
	private JedisCluster jedisCluster;
	
	@Test
	public void testJedisClusterSpring() throws Exception {
		//保存数据
		jedisCluster.set("xiena", "36");
		//取数据
		String num = jedisCluster.get("xiena");
		System.out.println(num);
	}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值