以下操作基于redis3.X版本:
Redis集群存储原理:Redis 集群使用数据分片(sharding),而非一致性哈希(consistency hashing)来实现,一个 Redis 集群包含 16384 个哈希槽,数据库中的每个键都属于这 16384 个哈希槽的其中一个,集群使用公式 CRC16(key) % 16384 来计算键 key 属于哪个槽,其中 CRC16(key) 语句用于计算键 key 的 CRC16 校验和。

Redis使用redis-trib.rb脚本来进行集群的创建和管理操作,该脚本是用ruby编写的,需要先安装ruby支持:

1、yum install zlib ruby rubygems

2、安装ruby的Redis插件:gem install redis
例:
redis-trib.rb create --replicate 1 server1:6379 server1:6380 server2:6379 server2:6380 server3:6379 server3:6380
--replicate 1: 一个副本的意思,上面整个命令的意思是创建三主三从的集群
注:
为真正实现集群的高可用,集群中的每个节点应位于不同的服务器上
如果只是用3台服务器创建6节点的集群,还是避免不了单台服务器宕机或网络故障导致数据写入不可用,从而导致系统不可用

添加主节点:
1)、添加节点:redis-trib.rb add-node new_server:port exists_server:exists_port
2)、重新分配哈希槽:redis-trib.rb reshard exists_master_server:exists_master_port,根据提示进行操作
3)、查看集群状态:redis-cli -c -h server:port cluster nodes

添加从节点:
1)、添加节点:redis-trib.rb add-node new_server:port exists_server:exists_port
2)、指定主节点:redis-cli -c -h new_server:port -> cluster replicate master_uid
3)、查看集群状态:redis-cli -c -h server:port cluster nodes

集群状态的调整:
假如有3台服务器搭建6节点的集群,集群状态如下:
server1:6380 slaveof server1:6379
server2:6380 slaveof server3:6379
server3:6380 slaveof server2:6379
这种集群状态是不合理的,合理的状态是主从交叉配置,一定程度上提升了高可用

在线调整:server1:6380的主调整为server2:6379,server3:6380的主调整为server1:6379
1)、删除server1:6380和server3:6380节点:redis-trib.rb del-node server1:6380 uid,redis-trib.rb del-node server3:6380 uid
2)、停止server1:6380和server3:6380节点:redis-cli -c -h server:port shutdown
3)、清空server1:6380和server3:6380节点的集群配置文件 cat /dev/null > server{1,3}:6380.conf
4)、开启server1:6380和server3:6380节点:redis-server -c 6380.conf
5)、指定主节点:redis-trib.rb add-node --slave --master-id server2_uid server1:6380 server2:6379
redis-trib.rb add-node --slave --master-id server1_uid server3:6380 server1:6379
6)、查看集群状态:redis-cli -c -h server:port cluster nodes

调整后的集群状态如下:
server1:6380 slaveof server2:6379
server2:6380 slaveof server3:6379
server3:6380 slaveof server1:6379

redis3集群管理的更多相关文章

  1. 译:Google的大规模集群管理工具Borg(一)------ 用户视角的Borg特性

    概述 Google的Borg系统是一个集群管理工具,在它上面运行着成千上万的job,这些job来自许许多多不同的应用,并且跨越多个集群,而每个集群又由大量的机器构成. Borg通过组合准入控制,高效的 ...

  2. 运维利器-ClusterShell集群管理操作记录

    在运维实战中,如果有若干台数据库服务器,想对这些服务器进行同等动作,比如查看它们当前的即时负载情况,查看它们的主机名,分发文件等等,这个时候该怎么办?一个个登陆服务器去操作,太傻帽了!写个shell去 ...

  3. elasticsearch集群管理工具head插件(转)

    elasticsearch-head是一个elasticsearch的集群管理工具,它是完全由html5编写的独立网页程序,你可以通过插件把它集成到es 插件安装方法1: 1.elasticsearc ...

  4. zookeeper安装和应用场合(名字,配置,锁,队列,集群管理)

    安装和配置详解 本文介绍的 Zookeeper 是以 3.2.2 这个稳定版本为基础,最新的版本可以通过官网http://hadoop.apache.org/zookeeper/ 来获取,Zookee ...

  5. [转载] 一共81个,开源大数据处理工具汇总(下),包括日志收集系统/集群管理/RPC等

    原文: http://www.36dsj.com/archives/25042 接上一部分:一共81个,开源大数据处理工具汇总(上),第二部分主要收集整理的内容主要有日志收集系统.消息系统.分布式服务 ...

  6. Docker&Kubernetes沙龙干货集锦:容器集群管理利器kubernetes详谈-CSDN.NET

    Docker&Kubernetes沙龙干货集锦:容器集群管理利器kubernetes详谈-CSDN.NET undefined Package - crawler undefined 科学网- ...

  7. 2 weekend110的zookeeper的原理、特性、数据模型、节点、角色、顺序号、读写机制、保证、API接口、ACL、选举、 + 应用场景:统一命名服务、配置管理、集群管理、共享锁、队列管理

    在hadoop生态圈里,很多地方都需zookeeper. 启动的时候,都是普通的server,但在启动过程中,通过一个特定的选举机制,选出一个leader. 只运行在一台服务器上,适合测试环境:Zoo ...

  8. Redis核心解读:集群管理工具(Redis-sentinel)

    Redis核心解读:集群管理工具(Redis-sentinel) - Redis - TechTarget数据库 Redis核心解读:集群管理工具(Redis-sentinel)

  9. 大规模集群管理工具Borg

    Google的大规模集群管理工具Borg 概述 Google的Borg系统是一个集群管理工具,在它上面运行着成千上万的job,这些job来自许许多多不同的应用,并且跨越多个集群,而每个集群又由大量的机 ...

随机推荐

  1. arcpy实例教程-地图范围导出到要素类

    arcpy实例教程-地图范围导出到要素类 商务合作,科技咨询,版权转让:向日葵,135-4855_4328,xiexiaokui#qq.com 功能:将当前地图范围导出到内存要素类 描述:将当前地图的 ...

  2. SpringMVC 给请求路径加上统一前缀

    最开始想到的是通过硬编码的方式手动在每个路径上加上前缀, 后面发现这种方式太不智能了,万一要修改那还不得改死, Spring既然支持EL表达式, 那能不能通过EL表达式的方式去读取配置文件里面的属性来 ...

  3. docker nginx安装

    安装nginx镜像docker search nginxdocker pull nginx 启动Nginx容器docker run -it -d --name n1 -v/home/n1/nginx. ...

  4. 常见的 35 个 Python 面试题及答案

    1. Python 面试问题及答案 作为一个 Python 新手,你必须熟悉基础知识.在本文中我们将讨论一些 Python 面试的基础问题和高级问题以及答案,以帮助你完成面试.包括 Python 开发 ...

  5. jdk1.7 64位官方下载

    平时要新装一个系统环境,或者下载最新的jdk,就需要到oracle官网去下载一个jdk,而目前生产环境都是1.7的环境下开发完成的,需要下载1.7版本的jdk,oracle官方网站的默认下载页面是1. ...

  6. Spring cloud微服务安全实战-7-3prometheus环境搭建

    Prmetheus 主要用来做来Metrics的监控和报警,这张图是官方的架构图. 这是他的核心 它的作用是根据我们的配置去完成数据的采集.服务的发现,以及数据的存储. 这是服务的发现,通过Servi ...

  7. [LeetCode] 49. Group Anagrams 分组变位词

    Given an array of strings, group anagrams together. For example, given: ["eat", "tea& ...

  8. python爬虫4猫眼电影的Top100

    1 查看网页结构 (1)确定需要抓取的字段 电影名称 电影主演 电影上映时间 电影评分 (2) 分析页面结构 按住f12------->点击右上角(如下图2)---->鼠标点击需要观察的字 ...

  9. docker+k8s基础篇四

    Docker+K8s基础篇(四) pod控制器 A:pod控制器类型 ReplicaSet控制器 A:ReplicaSet控制器介绍 B:ReplicaSet控制器的使用 Deployment控制器 ...

  10. 经典例题(Python)

    经典例题 if嵌套 1.用户输入账号2.用户输入密码3.判断用户的账号是不是alex4.如果账号是alex在继续判断密码是不是alexdsb5.账号和密码都正确提示用户alex就是一个dsb6.如果账 ...