Redis(四)-- 集群

一、Redis适合做企业级分布式缓存集群的条件

1.Redis内置哈希槽,有16384个哈希槽(0~16383),根据CRC16算法来确定这个集群中属于哪一个服务器来处理这个请求。

2.Redis提供一个集群管理工具:redis-trib,调度这些集群搭建,将这个集群中的每一组redis服务器联系起来。

二、Redis集群原理 

Redis 集群中内置了 16384 个哈希槽,当需要在 Redis 集群中放置一个 key-value时,redis 先对 key 使用 crc16 算法算出一个结果,然后把结果对 16384 求余数,这样每个 key 都会对应一个编号在 0-16383 之间的哈希槽,redis 会根据节点数量大致均等的将哈希槽映射到不同的节点。集群的每个节点负责一部分hash槽。这种结构很容易添加或者删除节点,并且无论是添加删除或者修改某一个节点,都不会造成集群不可用的状态。使用哈希槽的好处就在于可以方便的添加或移除节点。当需要增加节点时,只需要把其他节点的某些哈希槽挪到新节点就可以了;当需要移除节点时,只需要把移除节点上的哈希槽挪到其他节点就行了;在这一点上,我们以后新增或移除节点的时候不用先停掉所有的 redis 服务。

三、集群搭建

1.在/usr/java中新建cluster文件夹,然后在cluster文件夹中新建 1000 1001 2000 2001 3000 3001文件夹


   
   
  1. cd /usr/java

  2. mkdir cluster

  3. cd cluster

  4. mkdir 1000 1001 2000 2001 3000 3001

2.将redis.conf分别拷贝到1000 1001 2000 2001 3000 3001文件夹中

3.修改redis.conf文件中的


   
   
  1. port 1000      //端口1000 1001 2000 2001 3000 3001

  2. bind 本机ip     //默认ip为127.0.0.1,需要改为其他节点机器可访问的ip 否则创建集群时无法访问对应的端口,无法创建集群

  3. daemonize yes    //redis后台运行

  4. pidfile /usr/java/cluster/1000/redis.pid    //pidfile文件的位置,1000文件夹可以更换

  5. logfile /usr/java/cluster/1000/redis.log    //日志位置,1000文件夹可以更换

  6. cluster-enabled yes            //开启集群

  7. cluster-config-file /usr/java/cluster/1000/nodes.conf   //集群的配置

  8. cluster-node-timeout 15000        //请求超时 默认15秒,可自行设置

  9. appendonly yes            //aof日志开启 有需要就开启,它会每次写操作都记录一条日志 

4.安装ruby,都说必须要安装ruby2.0以上的,2.0以上自带rubygems包管理器,但我这里安装的是1.8.7,一样也可以。

1)yum install ruby 2)yum install rubygems 安装rubygems包管理器 3)gem install redis gem命令安装redis包,增加redis-trib.rb调用redis的接口包

5.将redis中的src文件夹下的 redis-trib.rb 拷贝到 /usr/local/bin 中,启动redis集群的时候,就不需要 进入到redis/src目录中了

6.启动redis集群,

redis-trib.rb create --replicas 1 192.168.242.130:1000 192.168.242.130:2000 192.168.242.130:3000 192.168.242.130:1001 192.168.242.130:2001 192.168.242.130:3001.

其中,--replicas 1 设置从节点个数,前三个是master,后三个是slave.

7.查看redis进程,ps -ef|grep redis

8.客户端连接,这里连接redis集群 要使用 redis-cli -c -h –p,其中 -c代表集群模式

redis-cli -c -h 192.168.242.130 -p 1000

9.查看集群是否成功:cluster info

10.当在1000中set值后,会看到自动切换到 3000,这是因为 刚刚 set的数据 落到了 3000中。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值