Redis 3.0入门二之集群搭建和使用
上一篇文章讲了redis的主从搭建,主从一般只能解决我们读写分离的问题,可以增加我们的系统的负载能力,但是并不能解决单点问题,大家应该知道在互联网公司各个服务肯定不能出现单点问题,所以这一节就记录一下如果让我们的系统更加高可用。
一、集群搭建
需要先说明的是,集群搭建需要至少6个节点:3主3从(因为没有那么多机器,所以就在一台上搞了)
1. 创建文件夹redis-cluster,然后在其下面分别创建6个文件夹,存放6个实例
mkdir -p /usr/local/redis-cluster mkdir 7001;mkdir 7002;mkdir 7003;mkdir 7004;mkdir 7005;mkdir 7006
2. 把之前redis.conf配置文件分别copy到700*下,修改各个实例的配置文件的内容,如下:
①. daemonize yes ②. port 700*(一台机器端口号肯定不能相同,就和文件夹一样吧) ③. bind ip(和当前机器的ip地址绑定) ④. dir /usr/local/redis-cluster/700*/(文件存储位置应该不一样吧,原因都知道) ⑤. cluster-enabled yes ⑥. cluster-config-flie nodes-700*.conf(700*就和端口一样吧) ⑦. cluster-node-timeout 5000 ⑧. appendonly yes
3. 安装ruby
yum install ruby yum install rubygems gem install redis
4. 启动各个实例
/usr/local/redis/bin/redis-server /usr/local/redis-cluster/700*/redis.conf
5. 创建集群
cd /usr/local/redis-3.0.0-rc2/src ./redis-trib.rb create --replicas 1 ip:7001 ip:7002 ip:7003 ip:7004 ip:7005 ip:7006
然后看输出日志,会有一步需要输入yes,然后集群就创建完成了
6. 验证,连接任意一个客户端即可
/usr/local/redis/bin/redis-cli -c -h -p (-c表示集群模式,指定ip和端口)
然后可以输入一些命令
cluster info cluster nodes
关闭集群时候要逐个进行关闭,命令就不贴了
7. 补充资料
友情提示,如果其群无法启动,可以删除临时的数据文件,再次重启每一个redis服务,然后重新构造集群环境
redis-trib.rb官方操作命令:http://redis.io/topics/cluster-tutorial
推荐博客:http://blog.51yip.com/nosql/1726.html/comment-page-1
redis-cli客户端命令:http://blog.csdn.net/qachenzude/article/details/32098777
二、集群使用
1. pom
<dependency> <groupId>redis.clients</groupId> <artifactId>jedis</artifactId> <version>2.7.2</version> </dependency>
2. 使用junit测试
package cn.bridgeli.msg.push.jedis; import java.util.HashSet; import java.util.Set; import org.junit.Test; import redis.clients.jedis.HostAndPort; import redis.clients.jedis.JedisCluster; import redis.clients.jedis.JedisPoolConfig; public class JedisClusterTest { @Test public void testJedisCluster() { Set<HostAndPort> jedisClusterNodes = new HashSet<HostAndPort>(); jedisClusterNodes.add(new HostAndPort("ip", 7001)); jedisClusterNodes.add(new HostAndPort("ip", 7002)); jedisClusterNodes.add(new HostAndPort("ip", 7003)); jedisClusterNodes.add(new HostAndPort("ip", 7004)); jedisClusterNodes.add(new HostAndPort("ip", 7005)); jedisClusterNodes.add(new HostAndPort("ip", 7006)); JedisPoolConfig jedisPoolConfig = new JedisPoolConfig(); jedisPoolConfig.setMaxTotal(100); jedisPoolConfig.setMaxIdle(20); jedisPoolConfig.setMaxWaitMillis(-1); jedisPoolConfig.setTestOnBorrow(true); JedisCluster jedisCluster = new JedisCluster(jedisClusterNodes, 5000, 1000, jedisPoolConfig); System.out.println(jedisCluster.set("name", "bridgeli")); System.out.println(jedisCluster.get("name")); } }
3. 和spring整合
... <context:property-placeholder location="classpath:jedis.properties" /> <context:component-scan base-package="cn.bridgeli" /> <bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig"> <property name="maxTotal" value="${redis.maxTotal}"></property> <property name="maxIdle" value="${redis.maxIdle}"></property> <property name="maxWaitMillis" value="${redis.maxWaitMillis}"></property> <property name="testOnBorrow" value="${redis.testOnBorrow}"></property> </bean> <bean id="hostAndPort1" class="redis.clients.jedis.HostAndPort"> <constructor-arg name="host" value="..."></constructor-arg> <constructor-arg name="port" value="..."></constructor-arg> </bean> <bean id="hostAndPort2" class="redis.clients.jedis.HostAndPort"> <constructor-arg name="host" value="..."></constructor-arg> <constructor-arg name="port" value="..."></constructor-arg> </bean> <bean id="hostAndPort3" class="redis.clients.jedis.HostAndPort"> <constructor-arg name="host" value="..."></constructor-arg> <constructor-arg name="port" value="..."></constructor-arg> </bean> <bean id="hostAndPort4" class="redis.clients.jedis.HostAndPort"> <constructor-arg name="host" value="..."></constructor-arg> <constructor-arg name="port" value="..."></constructor-arg> </bean> <bean id="hostAndPort5" class="redis.clients.jedis.HostAndPort"> <constructor-arg name="host" value="..."></constructor-arg> <constructor-arg name="port" value="..."></constructor-arg> </bean> <bean id="hostAndPort6" class="redis.clients.jedis.HostAndPort"> <constructor-arg name="host" value="..."></constructor-arg> <constructor-arg name="port" value="..."></constructor-arg> </bean> <bean id="jedisCluster" class="redis.clients.jedis.JedisCluster"> <constructor-arg name="nodes"> <set> <ref bean="hostAndPort1"/> <ref bean="hostAndPort2"/> <ref bean="hostAndPort3"/> <ref bean="hostAndPort4"/> <ref bean="hostAndPort5"/> <ref bean="hostAndPort6"/> </set> </constructor-arg> <constructor-arg name="timeout" value="5000"></constructor-arg> <constructor-arg name="poolConfig"> <ref bean="jedisPoolConfig"/> </constructor-arg> </bean> ...
至此,我们如何搭建redis主从、集群以及如何使用都应该可以完成了,最后我们发现这些其实并不难,关键是实践
全文完,如果本文对您有所帮助,请花 1 秒钟帮忙点击一下广告,谢谢。
作 者: BridgeLi,https://www.bridgeli.cn
原文链接:http://www.bridgeli.cn/archives/310
版权声明:非特殊声明均为本站原创作品,转载时请注明作者和原文链接。
作 者: BridgeLi,https://www.bridgeli.cn
原文链接:http://www.bridgeli.cn/archives/310
版权声明:非特殊声明均为本站原创作品,转载时请注明作者和原文链接。
近期评论