高可用 24小时对外提供服务

高并发 同一时间段能处理的请求数

1,中心化和去中心化

1.1,中心化

意思是所有的节点都要有一个主节点

缺点:中心挂了,服务就挂了

中心处理数据的能力有限,不能把节点性能发挥到最大

特点:就是一个路由作用

1.2,去中心化

特点:去掉路由,我自己来路由

以上通俗的就是

中心化:几个经过认证的嘉宾在‘讲话’,所有其他人在听。

去中心化:每个人都可以‘讲话’,每个人都可以选择听或者讲。


2,Redis集群的执行流程分析

2.1,哈希槽说明

Redis 集群中内置了 16384 个哈希槽,当需要在 Redis 集群中放置一个 key-value时,redis 先对 key 使用 crc16 算法算出一个结果,然后把结果对 16384 求余数,这样每个 key 都会对应一个编号在 0-16383 之间的哈希槽,redis 会根据节点数量大致均等的将哈希槽映射到不同的节点。

当你往Redis Cluster中加入一个Key时,会根据crc16(key) mod 16384计算这个key应该分布到哪个hash slot中,一个hash slot中会有很多key和value。你可以理解成表的分区,使用单节点时的redis时只有一个表,所有的key都放在这个表里;改用Redis Cluster以后会自动为你生成16384个分区表,你insert数据时会根据上面的简单算法来决定你的key应该存在哪个分区,每个分区里有很多key。

2.2,执行流程分析

假如redis集群里面能存放90个key,那么redis集群把90key平分到3个主机

redis对每个主机里面30个存储位置都编号,当应用连接到主机1上面时,应该发送一个写的命令

主机使用crc16算出槽号

如果槽号在1-30 可以直接操作主机1

如果槽号在31-60那么redis会转发到主机2

如果应该再发一个命令set age 22

那么主机2使用crc16再算槽号再转发


3,Redis集群的搭建

3.1,文档

http://redis.cn/topics/cluster-tutorial.html

3.2,原理:去中心化

3.3,集群规则

机器编号 ip port
1 192.168.120.129 7000
2 192.168.120.129 7001
3 192.168.120.129 7002
4 192.168.120.129 7003
5 192.168.120.129 7004
6 192.168.120.129 7005

3.4,搭建过程

3.4.1 新建文件夹

3.4.2 准备一个服务端程序

3.4.3准备6个redis的配置文件

下面进入redis.conf 配置文件修改配置

Redis-1

bind 0.0.0.0 69行

port 7000 92行

daemonize yes 136行

打开aof 持久化

appendonly yes 672行

开启集群

cluster-enabled yes 814行

集群的配置文件,该文件自动生成

cluster-config-file nodes-7000.conf 822行

集群的超时时间

cluster-node-timeout 5000 828行


Redis-2

daemonize yes

bind 0.0.0.0

port 7001

打开aof 持久化

appendonly yes

开启集群

cluster-enabled yes

集群的配置文件,该文件自动生成

cluster-config-file nodes-7001.conf

集群的超时时间

cluster-node-timeout 5000


Redis-3

daemonize yes

bind 0.0.0.0

port 7002

打开aof 持久化

appendonly yes

开启集群

cluster-enabled yes

集群的配置文件,该文件自动生成

cluster-config-file nodes-7002.conf

集群的超时时间

cluster-node-timeout 5000


Redis-4

daemonize yes

bind 0.0.0.0

port 7003

打开aof 持久化

appendonly yes

开启集群

cluster-enabled yes

集群的配置文件,该文件自动生成

cluster-config-file nodes-7004.conf

集群的超时时间

cluster-node-timeout 5000


Redis-5

daemonize yes

bind 0.0.0.0

port 7004

打开aof 持久化

appendonly yes

开启集群

cluster-enabled yes

集群的配置文件,该文件自动生成

cluster-config-file nodes-7005.conf

集群的超时时间

cluster-node-timeout 5000


Redis-6

daemonize yes

bind 0.0.0.0

port 7005

打开aof 持久化

appendonly yes

开启集群

cluster-enabled yes

集群的配置文件,该文件自动生成

cluster-config-file nodes-7006.conf

集群的超时时间

cluster-node-timeout 5000

3.4.4同时启动所有的redis

3.4.5 使用脚本创建集群(分配槽)

找到集群脚本,在src/src/redis-trib.rb 要安装Ruby的环境【不推荐

3.4.6 使用docker 下载redis-trib的镜像运行【推荐】

安装Docker

yum install docker

启动docker

systemctl start docker

A: 下载镜像

docker pull inem0o/redis-trib

docker run -it --net host inem0o/redis-trib create --replicas 1

192.168.120.129:7000 192.168.120.129:7001

192.168.120.129:7002 192.168.120.129:7003

192.168.120.129:7004 192.168.120.129:7005

-it是为了可以输入

--net host 是为了上docker容器能连接上本地的宿主机

3.4.7测试集群环境

-c 表示连接集群

到此集群搭建完成

05[掌握]高可用、集群、持久化、docker 等前置知识点的更多相关文章

  1. Nacos高可用集群解决方案-Docker版本

    文章主旨 本文目的是配置高可用的Nacos集群 架构图 整体架构为:Nginx + 3 x Nacos +高可用MySQL 高可用MySQL使用主从复制结构的可以参考Docker搭建MySQL主从集群 ...

  2. (六) Docker 部署 Redis 高可用集群 (sentinel 哨兵模式)

    参考并感谢 官方文档 https://hub.docker.com/_/redis GitHub https://github.com/antirez/redis happyJared https:/ ...

  3. (七) Docker 部署 MySql8.0 一主一从 高可用集群

    参考并感谢 官方文档 https://hub.docker.com/_/mysql y0ngb1n https://www.jianshu.com/p/0439206e1f28 vito0319 ht ...

  4. 基于docker实现redis高可用集群

    基于docker实现redis高可用集群 yls 2019-9-20 简介 基于docker和docker-compose 使用redis集群和sentinel集群,达到redis高可用,为缓存做铺垫 ...

  5. 消息中间件-ActiveMQ高可用集群和持久化机制

    1.修改active.mq的xml文件 2.延时.调度消息 package com.study.mq.b1_message; import org.apache.activemq.ActiveMQCo ...

  6. Kubeadm 1.9 HA 高可用集群本地离线镜像部署【已验证】

    k8s介绍 k8s 发展速度很快,目前很多大的公司容器集群都基于该项目,如京东,腾讯,滴滴,瓜子二手车,易宝支付,北森等等. kubernetes1.9版本发布2017年12月15日,每三个月一个迭代 ...

  7. ProxySQL Cluster 高可用集群环境部署记录

    ProxySQL在早期版本若需要做高可用,需要搭建两个实例,进行冗余.但两个ProxySQL实例之间的数据并不能共通,在主实例上配置后,仍需要在备用节点上进行配置,对管理来说非常不方便.但是Proxy ...

  8. Kubernetes容器集群 - harbor仓库高可用集群部署说明

    之前介绍Harbor私有仓库的安装和使用,这里重点说下Harbor高可用集群方案的部署,目前主要有两种主流的Harbor高可用集群方案:1)双主复制:2)多harbor实例共享后端存储. 一.Harb ...

  9. [K8s 1.9实践]Kubeadm 1.9 HA 高可用 集群 本地离线镜像部署

    k8s介绍 k8s 发展速度很快,目前很多大的公司容器集群都基于该项目,如京东,腾讯,滴滴,瓜子二手车,北森等等. kubernetes1.9版本发布2017年12月15日,每是那三个月一个迭代, W ...

  10. 【转】harbor仓库高可用集群部署说明

    之前介绍Harbor私有仓库的安装和使用,这里重点说下Harbor高可用集群方案的部署,目前主要有两种主流的Harbor高可用集群方案:1)双主复制:2)多harbor实例共享后端存储. 一.Harb ...

随机推荐

  1. day08 for循环与字符串掌握操作

    # 1.什么是for循环# 循环就是重复做某件事情,for循环是python提供第二种循环机制# 2.为何:理论上for循环可以做的事情while循环也可以做# for循环再循环取值(遍历取值)比wh ...

  2. Spring Cloud 系列之 Apollo 配置中心(三)

    本篇文章为系列文章,未读前几集的同学请猛戳这里: Spring Cloud 系列之 Apollo 配置中心(一) Spring Cloud 系列之 Apollo 配置中心(二) 本篇文章讲解 Apol ...

  3. Java实现 蓝桥杯 算法提高 拿糖果

    算法提高 拿糖果 时间限制:1.0s 内存限制:256.0MB 问题描述 妈妈给小B买了N块糖!但是她不允许小B直接吃掉. 假设当前有M块糖,小B每次可以拿P块糖,其中P是M的一个不大于根号下M的质因 ...

  4. Java实现蓝桥杯3n+1问题

    3n+1 [问题描述] 考虑如下的序列生成算法:从整数 n 开始,如果 n 是偶数,把它除以 2:如果 n 是奇数,把它乘 3 加1.用新得到的值重复上述步骤,直到 n = 1 时停止.例如,n = ...

  5. Java实现 蓝桥杯 历届试题 邮局

    问题描述 C村住着n户村民,由于交通闭塞,C村的村民只能通过信件与外界交流.为了方便村民们发信,C村打算在C村建设k个邮局,这样每户村民可以去离自己家最近的邮局发信. 现在给出了m个备选的邮局,请从中 ...

  6. Java实现第九届蓝桥杯书号验证

    书号验证 2004年起,国际ISBN中心出版了<13位国际标准书号指南>. 原有10位书号前加978作为商品分类标识:校验规则也改变. 校验位的加权算法与10位ISBN的算法不同,具体算法 ...

  7. java实现第三届蓝桥杯机器人行走

    机器人行走 [编程题](满分18分) 某少年宫引进了一批机器人小车.可以接受预先输入的指令,按指令行动.小车的基本动作很简单,只有3种:左转(记为L),右转(记为R),向前走若干厘米(直接记数字). ...

  8. Python之Flask框架二

    今天接着上一篇继续写一篇关于flask的随笔. 本文大纲: 1.获取请求参数 2.一个函数处理多个请求方式 3.重定向 4.错误响应 5.全局错误处理 6.返回json格式数据 7.自定义返回内容状态 ...

  9. Python内存管理机制-《源码解析》

    Python内存管理机制 Python 内存管理分层架构 /* An object allocator for Python. Here is an introduction to the layer ...

  10. 温故知新-多线程-深入刨析synchronized

    Posted by 微博@Yangsc_o 原创文章,版权声明:自由转载-非商用-非衍生-保持署名 | Creative Commons BY-NC-ND 3.0 文章目录 摘要 synchroniz ...