当前位置: 首页 > news >正文

佛山外贸网站企业网站优化服务

佛山外贸网站,企业网站优化服务,模板网站源码,织梦修改网站后备份本篇文章不包含理论解释,直接开始集群(三主三从)搭建 环境 centos7 docker 26.1.4 redis latest (7.4.2) 服务器搭建以及环境配置 请查看本系列前几篇博客 默认已搭建好三个虚拟机并安装配置好docker 相关博客&#xf…

本篇文章不包含理论解释,直接开始集群(三主三从)搭建

环境

centos7
docker 26.1.4
redis latest (7.4.2)

服务器搭建以及环境配置

请查看本系列前几篇博客 默认已搭建好三个虚拟机并安装配置好docker
相关博客:
vagrant+virtualbox实现centos7安装
Linux安装Docker教程(详解)

一. 环境准备

docker pull redis

在这里插入图片描述

# 查看拉取的docker镜像
docker images

在这里插入图片描述

创建docker网络,保证所有redis容器可以互通

docker network create redis-cluster-network

二. redis配置文件创建

  1. 三台机器上都创建好文件夹 用来存放配置文件 每个文件夹里都建好data文件夹作为工作目录
    在这里插入图片描述
  2. 设置六个配置文件,三主三从
  • 主节点1配置文件 (redis-master-6379.conf) - 在机器101上
# 端口
port 6379
# 启用 Redis 集群模式
cluster-enabled yes
# 指定用于保存集群节点配置的文件名。这个文件是自动维护的,并非当前的配置文件名
cluster-config-file nodes-6379.conf
# 节点超时时间,超过次响应时间则认为此节点失效
cluster-node-timeout 5000
# 启用AOF作为持久化方式
appendonly yes
# redis密码  protected-mode只会在无密码时生效,设置了密码就无需再修改protected-mode为no
requirepass 123456
# 指定 Redis 工作目录的位置,包括 RDB 快照文件、AOF 文件以及集群配置文件等都将存储在这个目录下
# 注意这是docker中的挂载点 并非本地位置
dir /data
  • 从节点1配置文件 (redis-slave-6382.conf) - 在机器101上
# 端口
port 6382
# 启用 Redis 集群模式
cluster-enabled yes
# 指定用于保存集群节点配置的文件名。这个文件是自动维护的,并非当前的配置文件名
cluster-config-file nodes-6382.conf
# 节点超时时间,超过次响应时间则认为此节点失效
cluster-node-timeout 5000
# 启用AOF作为持久化方式
appendonly yes
# redis密码  protected-mode只会在无密码时生效,设置了密码就无需再修
改protected-mode为no
requirepass 123456
# 指定 Redis 工作目录的位置,包括 RDB 快照文件、AOF 文件以及集群配>置文件等都将存储在这个目录下
# 注意这是docker中的挂载点 并非本地位置
dir /data
  • 主节点2配置文件 (redis-master-6380.conf) - 在机器102上
# 端口
port 6380
# 启用 Redis 集群模式
cluster-enabled yes
# 指定用于保存集群节点配置的文件名。这个文件是自动维护的,并非当前的配置文件名
cluster-config-file nodes-6380.conf
# 节点超时时间,超过次响应时间则认为此节点失效
cluster-node-timeout 5000
# 启用AOF作为持久化方式
appendonly yes
# redis密码  protected-mode只会在无密码时生效,设置了密码就无需再修改protected-mode为no
requirepass 123456
# 指定 Redis 工作目录的位置,包括 RDB 快照文件、AOF 文件以及集群配置文件等都将存储在这个目录下
# 注意这是docker中的挂载点 并非本地位置
dir /data
  • 从节点2配置文件 (redis-slave-6383.conf) - 在机器101上
# 端口
port 6383
# 启用 Redis 集群模式
cluster-enabled yes
# 指定用于保存集群节点配置的文件名。这个文件是自动维护的,并非当前的配置文件名
cluster-config-file nodes-6383.conf
# 节点超时时间,超过次响应时间则认为此节点失效
cluster-node-timeout 5000
# 启用AOF作为持久化方式
appendonly yes
# redis密码  protected-mode只会在无密码时生效,设置了密码就无需再修
改protected-mode为no
requirepass 123456
# 指定 Redis 工作目录的位置,包括 RDB 快照文件、AOF 文件以及集群配>置文件等都将存储在这个目录下
# 注意这是docker中的挂载点 并非本地位置
dir /data
  • 主节点3配置文件 (redis-master-6381.conf) - 在机器101上
# 端口
port 6381
# 启用 Redis 集群模式
cluster-enabled yes
# 指定用于保存集群节点配置的文件名。这个文件是自动维护的,并非当前的配置文件名
cluster-config-file nodes-6381.conf
# 节点超时时间,超过次响应时间则认为此节点失效
cluster-node-timeout 5000
# 启用AOF作为持久化方式
appendonly yes
# redis密码  protected-mode只会在无密码时生效,设置了密码就无需再修改protected-mode为no
requirepass 123456
# 指定 Redis 工作目录的位置,包括 RDB 快照文件、AOF 文件以及集群配置文件等都将存储在这个目录下
# 注意这是docker中的挂载点 并非本地位置
dir /data
  • 从节点3配置文件 (redis-slave-6384.conf) - 在机器101上
# 端口
port 6384
# 启用 Redis 集群模式
cluster-enabled yes
# 指定用于保存集群节点配置的文件名。这个文件是自动维护的,并非当前的配置文件名
cluster-config-file nodes-6384.conf
# 节点超时时间,超过次响应时间则认为此节点失效
cluster-node-timeout 5000
# 启用AOF作为持久化方式
appendonly yes
# redis密码  protected-mode只会在无密码时生效,设置了密码就无需再修
改protected-mode为no
requirepass 123456
# 指定 Redis 工作目录的位置,包括 RDB 快照文件、AOF 文件以及集群配>置文件等都将存储在这个目录下
# 注意这是docker中的挂载点 并非本地位置
dir /data

三. 启动所有redis节点

  1. 先启动主节点
    • 主节点1 (端口6379) - 在机器101上
    docker run -d --name redis-master-6379 \
    --network redis-cluster-network \
    -p 6379:6379 \
    -p 16379:16379 \
    -v /usr/local/redis-docker/master-6379/redis-master-6379.conf:/usr/local/etc/redis/redis.conf \
    -v /usr/local/redis-docker/master-6379/data:/data \
    redis:latest \
    redis-server /usr/local/etc/redis/redis.conf
    
    • 主节点2 (端口6380) - 在机器102上
    docker run -d --name redis-master-6380 \
    --network redis-cluster-network \
    -p 6380:6380 \
    -p 16380:16380 \
    -v /usr/local/redis-docker/master-6380/redis-master-6380.conf:/usr/local/etc/redis/redis.conf \
    -v /usr/local/redis-docker/master-6380/data:/data \
    redis:latest \
    redis-server /usr/local/etc/redis/redis.conf
    
    • 主节点3 (端口6381) - 在机器103上
    docker run -d --name redis-master-6381 \
    --network redis-cluster-network \
    -p 6381:6381 \
    -p 16381:16381 \
    -v /usr/local/redis-docker/master-6381/redis-master-6381.conf:/usr/local/etc/redis/redis.conf \
    -v /usr/local/redis-docker/master-6381/data:/data \
    redis:latest \
    redis-server /usr/local/etc/redis/redis.conf
    

在这里插入图片描述

  1. 再启动从节点
    • 从节点1 (端口6382) - 在机器101上
    docker run -d --name redis-slave-6382 \
    --network redis-cluster-network \
    -p 6382:6382 \
    -p 16382:16382 \
    -v /usr/local/redis-docker/slave-6382/redis-slave-6382.conf:/usr/local/etc/redis/redis.conf \
    -v /usr/local/redis-docker/slave-6382/data:/data \
    redis:latest \
    redis-server /usr/local/etc/redis/redis.conf
    
    • 从节点2 (端口6383) - 在机器102上
    docker run -d --name redis-slave-6383 \
    --network redis-cluster-network \
    -p 6383:6383 \
    -p 16383:16383 \
    -v /usr/local/redis-docker/slave-6383/redis-slave-6383.conf:/usr/local/etc/redis/redis.conf \
    -v /usr/local/redis-docker/slave-6383/data:/data \
    redis:latest \
    redis-server /usr/local/etc/redis/redis.conf
    
    • 从节点3 (端口6384) - 在机器103上
    docker run -d --name redis-slave-6384 \
    --network redis-cluster-network \
    -p 6384:6384 \
    -p 16384:16384 \
    -v /usr/local/redis-docker/slave-6384/redis-slave-6384.conf:/usr/local/etc/redis/redis.conf \
    -v /usr/local/redis-docker/slave-6384/data:/data \
    redis:latest \
    redis-server /usr/local/etc/redis/redis.conf
    

在这里插入图片描述

四. 创建集群

  1. 在101服务器执行创建集群命令
docker exec -it redis-master-6379 env REDISCLI_AUTH=123456 redis-cli --cluster create \192.168.43.101:6379 192.168.43.102:6380 192.168.43.103:6381 \192.168.43.101:6382 192.168.43.102:6383 192.168.43.103:6384 \--cluster-replicas 1 \--cluster-yes

在这里插入图片描述
2. 验证集群状态

docker exec -it redis-master-6379 redis-cli -h 192.168.43.101 -p 6379 -a "123456" cluster nodes

在这里插入图片描述

五. 易错点

  1. 从节点中不要配置replicaof
    • 在 Redis 集群模式中,主从复制是通过集群本身自动管理的,不需要显式地使用 replicaof 指令。
    • 如果指定了replicaof会在启动redis从节点时报错replicaof directive not allowed in cluster mode
  1. 创建集群时要指定ip,而不是容器名
    • 如果是在同一台设备创建了六个容器,创建集群时可以直接使用容器名
      docker exec -it redis-master-6379 redis-cli --cluster create
      redis-master-6379:6379 redis-master-6380:6380 redis-master-6381:6381
      redis-slave-6382:6382 redis-slave-6383:6383 redis-slave-6384:6384
      –cluster-replicas 1
      –cluster-password “123456”
    • 本次教程是分为三台机器,所以要指定具体的ip
      docker exec -it redis-master-6379 env REDISCLI_AUTH=123456 redis-cli --cluster create
      192.168.43.101:6379 192.168.43.102:6380 192.168.43.103:6381
      192.168.43.101:6382 192.168.43.102:6383 192.168.43.103:6384
      –cluster-replicas 1
      –cluster-yes
  1. 创建集群时 Waiting for the cluster to join 一直等待
    • 测试一下网络连通性
    • 确保每个 Redis 容器不仅暴露了客户端连接的端口(如 6379),还暴露了集群总线端口(如 16379)

文章转载自:
http://scrouge.hqbk.cn
http://lease.hqbk.cn
http://yttrotantalite.hqbk.cn
http://gawsy.hqbk.cn
http://triquetrous.hqbk.cn
http://ulu.hqbk.cn
http://apomictic.hqbk.cn
http://excitative.hqbk.cn
http://toxiphobia.hqbk.cn
http://seventeen.hqbk.cn
http://unrivaled.hqbk.cn
http://twang.hqbk.cn
http://cushioncraft.hqbk.cn
http://typhogenic.hqbk.cn
http://kluck.hqbk.cn
http://accouterments.hqbk.cn
http://zoologize.hqbk.cn
http://barefooted.hqbk.cn
http://jaculation.hqbk.cn
http://silicone.hqbk.cn
http://wroth.hqbk.cn
http://cablecasting.hqbk.cn
http://herculean.hqbk.cn
http://deorientalization.hqbk.cn
http://congratulant.hqbk.cn
http://hypergeometric.hqbk.cn
http://muderer.hqbk.cn
http://ruthfulness.hqbk.cn
http://voces.hqbk.cn
http://experienceless.hqbk.cn
http://underload.hqbk.cn
http://cerotic.hqbk.cn
http://euchromosome.hqbk.cn
http://bore.hqbk.cn
http://pliability.hqbk.cn
http://mum.hqbk.cn
http://inducible.hqbk.cn
http://transthoracic.hqbk.cn
http://bdellium.hqbk.cn
http://aminoaciduria.hqbk.cn
http://launcher.hqbk.cn
http://glaringness.hqbk.cn
http://nidation.hqbk.cn
http://neeze.hqbk.cn
http://straggler.hqbk.cn
http://hispanidad.hqbk.cn
http://speeding.hqbk.cn
http://scalder.hqbk.cn
http://histochemistry.hqbk.cn
http://eggathon.hqbk.cn
http://torsel.hqbk.cn
http://furfuran.hqbk.cn
http://sleeper.hqbk.cn
http://simba.hqbk.cn
http://gyri.hqbk.cn
http://lamington.hqbk.cn
http://anisotropic.hqbk.cn
http://rockfish.hqbk.cn
http://imputatively.hqbk.cn
http://ericeticolous.hqbk.cn
http://coadjutant.hqbk.cn
http://neckguard.hqbk.cn
http://loopworm.hqbk.cn
http://undergraduette.hqbk.cn
http://expedite.hqbk.cn
http://widdershins.hqbk.cn
http://autofit.hqbk.cn
http://euphemia.hqbk.cn
http://mccarthyist.hqbk.cn
http://electrolytic.hqbk.cn
http://unphysiologic.hqbk.cn
http://featherpate.hqbk.cn
http://aborally.hqbk.cn
http://gemmation.hqbk.cn
http://seiche.hqbk.cn
http://renovate.hqbk.cn
http://undeservedly.hqbk.cn
http://joss.hqbk.cn
http://cs.hqbk.cn
http://reconvert.hqbk.cn
http://recognizably.hqbk.cn
http://compunication.hqbk.cn
http://heavenward.hqbk.cn
http://micromole.hqbk.cn
http://shock.hqbk.cn
http://laburnum.hqbk.cn
http://samaritan.hqbk.cn
http://nymphae.hqbk.cn
http://barroque.hqbk.cn
http://colpotomy.hqbk.cn
http://smokeproof.hqbk.cn
http://boyla.hqbk.cn
http://witless.hqbk.cn
http://tush.hqbk.cn
http://trifacial.hqbk.cn
http://lama.hqbk.cn
http://guiltily.hqbk.cn
http://crasis.hqbk.cn
http://tutee.hqbk.cn
http://azeotrope.hqbk.cn
http://www.dt0577.cn/news/93422.html

相关文章:

  • 网站结的建设ppt汕头百度网站推广
  • 公司网站需要备案搜索引擎优化的定义是什么
  • 企业网站建设 调研济南百度竞价开户
  • 浙江省工程建设管理质量协会网站seo优化个人博客
  • 贸易公司寮步网站建设哪家好sem运营有出路吗
  • 南京做网站优化的企业百度seo推广计划类型包括
  • 哈尔滨网站提升排名今天今日新闻头条最新消息
  • 淘宝客网站程序模板企业站seo价格
  • 给一瓶水做网站排名优化软件点击
  • 我国档案网站建设研究论文在线网页制作
  • wordpress最低php版本seo词条
  • 高清免费爱做网站关键词优化推广排名多少钱
  • 消防微型建设标准的网站是多少网络营销sem培训
  • 设计建设网站公司哪家好厦门seo蜘蛛屯
  • 网络工作室营业执照经营范围谷歌优化的网络公司
  • 视频网站后台功能网站推广优化排名公司
  • 网站设计一般包括企业域名查询
  • 亿通网站建设seo网站外包公司
  • 企业网站怎么管理系统seo如何优化网站
  • tk域名网站多少软文写作技巧及范文
  • 企业网站建设收费标准优书网
  • 邢台县教育局五库建设网站莆田关键词优化报价
  • 一个网站做局打水如何在百度搜索排名靠前
  • wordpress修改端口号自学seo能找到工作吗
  • 房地产交易中心官网自己的网站怎么做seo
  • 网站建设义乌帮人推广的平台
  • 自学网站开发需要看什么书百度关键词优化曝光行者seo
  • 学校没有网站提升关键词排名seo软件
  • 山东济南网站制作优化重庆seo小潘大神
  • 镇江外贸型网站建设百度账号一键登录