一.Redis Cluster简介

Redis Cluster集群是一种去中心化的高可用服务,其内置的sentinel功能可以提供高可用性:当集群中少数master不可用时,该集群仍可用。

Cluster集群通过哈希槽算法来分片存储数据。集群中有16384(0-16383)个哈希槽,通过CRC16算法对要存取的变量得出值,%16384 得到的余数存入相应的槽范围的主库,或从中取出。

客户端访问集群中的任意一台机器,都可以存取数据;访问集群中的从库时,数据存取时会连接主库再执行操作。从库会自动同步主库的数据。

二.部署

redis5版本以上的cluster集群不需要依赖ruby.生产环境中一个redis cluster集群最少需要6台机器(3主3从,3主6从,...),此次为测试环境,故选用三台机器,每台机器上启动两个服务。

  1. 环境说明:
  2. 系统:centos7.6
  3. redis版本:5.0.8
  4. 服务器&&IP
  5. 172.31.228.200:6379
  6. 172.31.228.200:6380
  7. 172.31.228.201:6379
  8. 172.31.228.201:6380
  9. 172.31.228.199:6379
  10. 172.31.228.199:6380

1.运行安装脚本(以172.31.228.200:6379为例,此为单机版安装脚本):

  1. centos_version=7
  2. password=5gUfpN1wgQr5t$e^nutaxKQp
  3. private_ip=`ip a | grep eth0 | grep inet | awk '{print $2}' |awk -F / '{print $1}'`
  4. config_file=/etc/redis.conf
  5. port=6379
  6. yum -y install gcc
  7. yum install -y [http://rpms.famillecollet.com/enterprise/remi-release-${centos_version}.rpm](http://rpms.famillecollet.com/enterprise/remi-release-${centos_version}.rpm)
  8. yum --enablerepo=remi -y install redis #安装最新版本的redis
  9. sed -i -r 69s/bind (.*)+/bind ${private_ip}/ ${config_file} #
  10. sed -i 92s/6379/${port}/ ${config_file} #port
  11. sed -i \'136s/no/yes/\' ${config_file} #daemonize
  12. sed -i \'147s/no/systemd/\' ${config_file} #supervised 设置为systemd
  13. sed -i 158s/6379/${port}/ ${config_file}
  14. sed -i \'699s/no/yes/\' ${config_file} #appendonly
  15. sed -i -r \'507s/^#(.*)+/\\1/\' ${config_file}
  16. sed -i 507s/foobared/${password}/ ${config_file} #requirepass
  17. echo
  18. rename-command CONFIG redis${port}config #重命名高危命令
  19. rename-command SHUTDOWN redis${port}shutdown #重命名高危命令
  20. rename-command FLUSHDB \'\' #禁用高危命令
  21. rename-command FLUSHALL \'\' #禁用高危命令
  22. >> ${config_file}
  23. chmod 600 ${config_file} #修改配置文件的权限
  24. sed -i \'12a Restart=always \' /usr/lib/systemd/system/redis.service #设置redis服务自动重启
  25. sed -i \'13a StartLimitIntervalSec=0\' /usr/lib/systemd/system/redis.service #设置服务启动间隔时间为0
  26. systemctl daemon-reload #重新加载systemd
  27. systemctl start redis.service #启动服务
  28. systemctl enable redis.service #设置开机自启

2.然后修改配置文件/etc/redis.conf

  1. cluster-enabled yes #去掉注释
  2. cluster-config-file nodes-6379.conf #去掉注释
  3. cluster-node-timeout 15000 #去掉注释
  4. masterauth 5gUfpN1wgQr5t$e^nutaxKQp #开启集群间密码验证

3.重启服务:

systemctl restart reids.service

其他五个节点按上述3个步骤进行(注意修改port,dir(创建数据库目录并修改权限),redis.conf名,pidfile, logfile, redis.service文件名及其内配置的启动命令)

接下来可在任意一个节点配置集群,集群设置方法有两种,

方法1:先指定主库,再添加从库到对应主库

三.创建主库

redis-cli --cluster create 172.31.228.200:6379 172.31.228.201:6379 172.31.228.199:6379 -a 5gUfpN1wgQr5t$e^nutaxKQp --cluster-yes

配置从节点

  1. ]# redis-cli --cluster add-node 172.31.228.200:6380 172.31.228.200:6379 --cluster-slave --cluster-master-id 19c5b8deaf079ebb9832b6eefefa74c0c05a18b2 -a \'5gUfpN1wgQr5t$e^nutaxKQp\'
  2. ]# redis-cli --cluster add-node 172.31.228.201:6380 172.31.228.201:6379 --cluster-slave --cluster-master-id 011326dd0ef2888e3ee8ed5590e5ee600dc96462 -a \'5gUfpN1wgQr5t$e^nutaxKQp\'
  3. ]# redis-cli --cluster add-node 172.31.228.199:6380 172.31.228.199:6379 --cluster-slave --cluster-master-id bfb1b52df455e9bbadeda19c16512f7378fd5e45 -a \'5gUfpN1wgQr5t$e^nutaxKQp\'

方法2:让集群自动分配主从

redis-cli --cluster create 172.31.228.200:6379 172.31.228.200:6380 172.31.228.201:6379 172.31.228.201:6380 172.31.228.199:6379 172.31.228.199:6380 --cluster-replicas 1 -a \'5gUfpN1wgQr5t$e^nutaxKQp\'

以上图片表示集群创建成功。

可登录集群查看节点信息

Note:以上slots经过reshard(具体操作如下:)

redis-cli --cluster reshard localhost:6379 --cluster-from d878b9824c97eab686a57403bbed3270b7cd98f9 --cluster-to 578ffc16a9780675d39e1ba9d48e91743a4a01cb --cluster-slots 100 -a '5gUfpN1wgQr5t$e^nutaxKQp'

测试master不可用时,slave晋升为新master,集群仍可用,旧master重启后会自动变成slave.(若集群中某个master节点和其对应的slave节点同时不可用时,则集群不可用;或者n/2+1个master不可用时,则集群不可用)。

Redis5.0.8 Cluster集群部署的更多相关文章

  1. centos6下redis cluster集群部署过程

    一般来说,redis主从和mysql主从目的差不多,但redis主从配置很简单,主要在从节点配置文件指定主节点ip和端口,比如:slaveof 192.168.10.10 6379,然后启动主从,主从 ...

  2. Centos 7 下 Mysql 5.7 Galera Cluster 集群部署

     一.介绍 传统架构的使用,一直被人们所诟病,因为MySQL的主从模式,天生的不能完全保证数据一致,很多大公司会花很大人力物力去解决这个问题,而效果却一般,可以说,只能是通过牺牲性能,来获得数据一致性 ...

  3. MySQL Cluster 集群部署

    前言 此篇博客用以介绍 MySQL Cluster 集群部署方法 一.节点规划 序号 IP地址 节点名称 1 172.16.1.201 mysql-manage 2 172.16.1.202 mysq ...

  4. 2、Redis 底层原理:Cluster 集群部署与详解

    Redis 简介 Redis 提供数据缓存服务,内部数据都存在内存中,所以访问速度非常快. 早期,Redis 单应用服务亦能满足企业的需求.之后,业务量的上升,单机的读写能力满足不了业务的需求,技术上 ...

  5. k8s1.9.0安装--完整集群部署

    三.完整集群部署 - kubernetes-with-ca 1. 理解认证授权 1.1 为什么要认证 想理解认证,我们得从认证解决什么问题.防止什么问题的发生入手.防止什么问题呢?是防止有人入侵你的集 ...

  6. k8s1.9.0安装--基础集群部署

    二.基础集群部署 - kubernetes-simple 1. 部署ETCD(主节点) 1.1 简介 kubernetes需要存储很多东西,像它本身的节点信息,组件信息,还有通过kubernetes运 ...

  7. Redis cluster 集群部署和配置

    目录 一.集群简介 cluster介绍 cluster原理 cluster特点 应用场景 二.集群部署 环境介绍 节点部署 启动集群 三.集群测试 一.集群简介 cluster介绍 redis clu ...

  8. redis cluster集群部署

    上一篇http://www.cnblogs.com/qinyujie/p/9029153.html,主要讲解了 redis cluster 集群架构 的优势.redis cluster 和 redis ...

  9. docker镜像创建redis5.0.3容器集群

    拉取redis5.0.3镜像 # docker pull daocloud.io/library/redis:5.0.3 [root@localhost ~]# docker pull daoclou ...

随机推荐

  1. 大爽Python入门教程 3-4 实践例题

    大爽Python入门公开课教案 点击查看教程总目录 1. 求和 使用循环,计算列表所有项的和,并输出这个和. 列表示例 lst = [8, 5, 7, 12, 19, 21, 10, 3, 2, 11 ...

  2. GIS应用|快速开发REST空间分析服务

    随着计算机的快速发展,GIS已经在各大领域得到应用,和我们的生活息息相关, 但是基于GIS几大厂商搭建服务,都会有一定的门槛,尤其是需要server,成本高,难度大,这里介绍一种在线GIS云平台,帮你 ...

  3. 猿猿有责,维持整洁的 Git 提交记录,三个锦囊送给你

    背景 大家都有学习如何规范简洁的编写代码,但却很少学习如何规范简洁的提交代码.现在大家基本上都用 Git 作为源码管理的工具,Git 提供了极大的灵活性,我们按照各种 workflow 来提交/合并 ...

  4. [loj2504]小H爱染色

    以下考虑直接对所有$F(A)$求和,并给出两种做法-- 做法1: 枚举答案$A$,对应方案数为${n-A\choose m}^{2}-{n-A-1\choose m}^{2}$,即答案为$\sum_{ ...

  5. shiro 学习笔记

    1. 权限管理 1.1 什么是权限管理? 权限管理实现对用户访问系统的控制,按照安全规则或者安全策略,可以控制用户只能访问自己被授权的资源 权限管理包括用户身份认证和授权两部分,简称认证授权 1.2 ...

  6. java 单例模式实现代码

    目录 1.使用静态内部类实现 2.使用枚举实现 3.序列化与反序列化 1.使用静态内部类实现 使用静态内部类实现单例模式,线程安全 class SingletonStaticInner { priva ...

  7. CODE FESTIVAL 2017 qual C F - Three Gluttons(DP)

    洛谷题面传送门 & Atcoder 题面传送门 DP 好题. 首先考虑如果我们知道 C 吃了哪些寿司,能够还原出多少种符合条件的序列.我们考虑倒着钦定,即,先钦定 A,B,C 三者最后吃的那三 ...

  8. Atcoder Grand Contest 031 D - A Sequence of Permutations(置换+猜结论)

    Atcoder 题面传送门 & 洛谷题面传送门 猜结论神题. 首先考虑探究题目中 \(f\) 函数的性质,\(f(p,q)_{p_i}=q_i\leftarrow f(p,q)\circ p= ...

  9. Python list的深拷贝和浅拷贝

    深拷贝和浅拷贝 列表存储数据,列表拷贝就是数据备份 浅拷贝 优点:占用内存较少 缺点:修改深层数据,会影响原数据 深拷贝 优点:修改数据,互不影响 缺点:占用内存较大 ""&quo ...

  10. Windows下的Python多版本管理?

    虽然接触了好几年python,但一些细节没有注意.最近看网课,看到这个Windows系统下Python多版本管理的问题,记录下备忘. 假设现在windows环境中有python2,python3和an ...