一.Redis Cluster简介

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

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

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

二.部署

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

环境说明:
系统:centos7.6
redis版本:5.0.8 服务器&&IP:
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

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

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

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

cluster-enabled yes #去掉注释
cluster-config-file nodes-6379.conf #去掉注释
cluster-node-timeout 15000 #去掉注释
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

配置从节点

]# 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\'

]# 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\'

]# 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. Django笔记&教程 5-3 综合使用示例

    Django 自学笔记兼学习教程第5章第3节--综合使用示例 点击查看教程总目录 1 - 生成学号场景 场景描述: 教务管理系统中,学生注册账号,学生选择年级后,生成唯一学号. 细节分析: 学生学号由 ...

  2. scrapy获取当当网中数据

    yield 1. 带有 yield 的函数不再是一个普通函数,而是一个生成器generator,可用于迭代 2. yield 是一个类似 return 的关键字,迭代一次遇到yield时就返回yiel ...

  3. 【Microsoft Azure 的1024种玩法】一.一分钟快速上手搭建宝塔管理面板

    简介 宝塔Linux面板是提升运维效率的服务器管理软件,其支持一键LAMP/LNMP/集群/监控/网站/FTP/数据库/JAVA等100多项服务器管理功能.今天带大家一起学习的内容为一分钟快速上手搭建 ...

  4. [atAGC045C]Range Set

    首先我们可以把所有位置都变为1,因此不妨假设$a\le b$ 一个字符串$s$合法当且仅当:将其中每一段长度不小于$a$的0变成1后,存在一段1的长度都不小于$b$ 证明:我们称$S_{a,b}$为通 ...

  5. 联盛德 HLK-W806 (四): 软件SPI和硬件SPI驱动ST7735液晶LCD

    目录 联盛德 HLK-W806 (一): Ubuntu20.04下的开发环境配置, 编译和烧录说明 联盛德 HLK-W806 (二): Win10下的开发环境配置, 编译和烧录说明 联盛德 HLK-W ...

  6. Web Api 宿主的搭建

    首先我们要清楚一个概念,宿主.宿主是什么意思?先从了解一下Hosting开始吧! 有关Hosting的基础知识 Hosting是一个非常重要,但又很难翻译成中文的概念.翻译成:寄宿,大概能勉强地传达它 ...

  7. Ubuntu怎么修改DNS

    有时候会出现配置好网络之后,可以ping通网关却ping不通www.baidu.com orangepi@orangepi3:~$ ping 192.168.1.1 PING 192.168.1.1 ...

  8. c语言实参与形参的区别

    1 #include<stdio.h> 2 #include<math.h> 3 4 /** 5 * 形参和实参的功能是作数据传送. 6 * 函数调用中发生的数据传送是单向的. ...

  9. Codeforces 429E - Points and Segments(欧拉回路)

    Codeforces 题面传送门 & 洛谷题面传送门 果然我不具备融会贯通的能力/ll 看到这样的设问我们可以很自然地联想到这道题,具体来说我们可以通过某种方式建出一张图,然后根据" ...

  10. 【机器学习与R语言】13- 如何提高模型的性能?

    目录 1.调整模型参数来提高性能 1.1 创建简单的调整模型 2.2 定制调整参数 2.使用元学习来提高性能 2.1 集成学习(元学习)概述 2.2 bagging 2.3 boosting 2.4 ...