以下操作基于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. semi-join子查询优化 -- semi-join Materialization策略

    semi-join Materialization 是用于semi-join的一种特殊的子查询物化技术.通常包含两种策略:1.Materialization/lookup2.Materializati ...

  2. http使用formData方式传输文件请求

    转载请注明出处: 项目中有遇到http使用formData请求传输文件,在此记录一下 1.依赖jar包: <dependency> <groupId>org.apache.ht ...

  3. LODOP中的RightMargin右边距和BottomMargin下边距

    LODOP中的打印项,例如ADD_PRINT_HTM,参数分别为顶边距,左边距,宽,高,打印项内容.第三四参数宽高,除了可以用值和百分比,还可以用RightMargin和BottomMargin变相控 ...

  4. 【c++基础】C与C++接口相互调用

    前言 编译程序的时候出现错误,入口程序如果是cpp文件可以编译成功,如果是c程序则出错.一般这个问题是c与c++之间接口相互调用出现的问题. 出现的错误是undefined reference to ...

  5. Linux开机报错,提示根目录有错误,无法通过检测进入系统

    报错信息如下: VolGroup-lv_root contains a file system with errors, check forced. 修复方法:(因为我的是虚拟机,可以随意做备份,所以 ...

  6. Jenkins - 安装并启动Jenkins

    1 - 关于Jenkins 构建流水线(build pipeline)工具Jenkins可以轻松地定义和管理各种各样的操作(构建.测试等),并将这些操作像管道pipe一样自由地进行组合,从而自动.流畅 ...

  7. (转)Java中的String为什么是不可变的? -- String源码分析

    背景:被问到很基础的知识点  string  自己答的很模糊 Java中的String为什么是不可变的? -- String源码分析 ps:最好去阅读原文 Java中的String为什么是不可变的 什 ...

  8. sql 查找所有员工信息(俩表连接查询)

    题目描述 查找所有员工的last_name和first_name以及对应部门编号dept_no,也包括展示没有分配具体部门的员工CREATE TABLE `dept_emp` (`emp_no` in ...

  9. grok语法定义

    grok默认表达式 Logstash 内置了120种默认表达式,可以查看patterns,里面对表达式做了分组,每个文件为一组,文件内部有对应的表达式模式.下面只是部分常用的. 常用表达式 表达式标识 ...

  10. Python2.7+virtualenv+CUDA 10.0版的pytorch v1.3.0 +运行人群计数crowdcount-mcnn网络

    Python2.7$ python2 -m virtualenv pytorchenv$ source pytorchenv/bin/activate $ pip install ipython py ...