高可用高并发集群配置
1.简介
高可用 24小时对外提供服务
高并发 同一时间段能处理的请求数
2.中心化和去中心化
中心化
意思是所有的节点都要有一个主节点
缺点:中心挂了,服务就挂了
中心处理数据的能力有限,不能把节点性能发挥到最大
特点:就是一个路由作用
data:image/s3,"s3://crabby-images/92201/92201143de584d527c3f04dbc6c27334a515435f" alt=""
去中心化
特点:去掉路由,我自己来路由
data:image/s3,"s3://crabby-images/02810/02810b809fe46e0937a5e7e47d033fe6aae5c8c4" alt=""
以上通俗的就是
中心化:几个经过认证的嘉宾在‘讲话’,所有其他人在听。
去中心化:每个人都可以‘讲话’,每个人都可以选择听或者讲。
3.Redis集群的执行流程分析
哈希槽说明
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。
执行流程分析
假如redis集群里面能存放90个key,那么redis集群把90key平分到3个主机
redis对每个主机里面30个存储位置都编号,当应用连接到主机1上面时,应该发送一个写的命令
主机使用crc16算出槽号
如果槽号在1-30 可以直接操作主机1
如果槽号在31-60那么redis会转发到主机2
如果应该再发一个命令set age 22
那么主机2使用crc16再算槽号再转发
4.Redis集群的搭建
文档
原理:
去中心化
集群规则
data:image/s3,"s3://crabby-images/8b8e5/8b8e51203fc3925776b731057a975e4c35b034f5" alt=""
搭建过程
新建文件夹
data:image/s3,"s3://crabby-images/0fd0f/0fd0f15703913565ecbcbc2cd80b6e51cd8b5bff" alt=""
准备一个服务端程序
data:image/s3,"s3://crabby-images/615cd/615cdb699d693d0bb9e8ad92a730efc4eb437818" alt=""
准备6个redis的配置文件
data:image/s3,"s3://crabby-images/60338/60338cfdf1bc7c1c98f6dddeacb3ff5a72e94da2" alt=""
data:image/s3,"s3://crabby-images/7ca48/7ca48e4bb2e914e1b1ef93d02506f987fc9e2b36" alt=""
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
同时启动所有的redis
data:image/s3,"s3://crabby-images/536e9/536e996d5c25f4264dc653e01347ed552f64d4ff" alt=""
使用脚本创建集群(分配槽)
找到集群脚本,在src/src/redis-trib.rb 要安装Ruby的环境【不推荐
使用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容器能连接上本地的宿主机
data:image/s3,"s3://crabby-images/273fd/273fdbc36c14067ba54eecc167c6bad7601f93ca" alt=""
data:image/s3,"s3://crabby-images/909f8/909f88f39285526887c6e12cb542dd8f1560fd8a" alt=""
3.4.7测试集群环境
data:image/s3,"s3://crabby-images/fc267/fc267d2e589f029ff1f6cce59cdae1710e7460f3" alt=""
-c 表示连接集群
data:image/s3,"s3://crabby-images/559b5/559b54cc3c5a8a3d7433fe87d1931384bd39ce68" alt=""
data:image/s3,"s3://crabby-images/e1e95/e1e959954c7783bd9922ff7470d742986dfd718d" alt=""
data:image/s3,"s3://crabby-images/91768/91768cabf91d361bd837f9ce6be174c96cda13ae" alt=""
到此集群搭建完成
去中心化去中心化
网友评论