iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >Docker-Compose如何搭建Redis集群
  • 836
分享到

Docker-Compose如何搭建Redis集群

2023-07-05 16:07:07 836人浏览 独家记忆
摘要

本篇内容介绍了“Docker-Compose如何搭建Redis集群”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1. 集群配置3主+3从由于

本篇内容介绍了“Docker-Compose如何搭建Redis集群”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

1. 集群配置

  • 3主+3从

  • 由于仅用于测试,故我这里只用1台服务器进行模拟

Redis列表

Docker-Compose如何搭建Redis集群

2.编写redis.conf

在server上创建一个目录用于存放redis集群部署文件。这里我放的路径为/root/redis-cluster

在/opt/docker/redis-cluster目录下创建redis-1,redis-2,redis-3,redis-4,redis-5,redis-6文件夹

mkdir -p /opt/docker/redis-cluster/{redis-1,redis-2,redis-3,redis-4,redis-5,redis-6} #创建持久化目录mkdir -p /opt/docker/redis-cluster/redis-1/datamkdir -p /opt/docker/redis-cluster/redis-2/datamkdir -p /opt/docker/redis-cluster/redis-3/datamkdir -p /opt/docker/redis-cluster/redis-4/datamkdir -p /opt/docker/redis-cluster/redis-5/datamkdir -p /opt/docker/redis-cluster/redis-6/data

3. 在每个redis-*文件夹下创建redis.conf文件,并写入如下内容:

cluster-enabled yes # 开启集群cluster-config-file nodes.conf # 集群配置文件cluster-node-timeout 5000 # 集群节点多少时间未响应视为该节点丢失appendonly yesport 6379 # redis监听端口masterauth passwd123  #设置master节点密码requirepass passwd123 #设置密码

注意:port值不能都为6379,根据上面redis列表设置的端口号,依次给redis-1 ~ redis-6设置6379~6384端口号

4.编写docker-compose.yml文件

这里直接使用daocloud提供的redis镜像地址daocloud.io/library/redis:6.0.4

在/root/redis-cluster文件夹下创建docker-compose.yml文件。

docker-compose.yml文件内容如下:

version: '3.1'services:  # redis1配置  redis1:    image: daocloud.io/library/redis:6.0.4    container_name: redis-1    restart: always    network_mode: "host"    volumes:      - /opt/docker/redis-cluster/redis-1/data:/data      - /opt/docker/redis-cluster/redis-1/redis.conf:/usr/local/etc/redis/redis.conf    command: ["redis-server", "/usr/local/etc/redis/redis.conf"]  # redis2配置  redis2:    image: daocloud.io/library/redis:6.0.4    container_name: redis-2    restart: always    network_mode: "host"    volumes:      - /opt/docker/redis-cluster/redis-2/data:/data      - /opt/docker/redis-cluster/redis-2/redis.conf:/usr/local/etc/redis/redis.conf    command: ["redis-server", "/usr/local/etc/redis/redis.conf"]  # redis3配置  redis3:    image: daocloud.io/library/redis:6.0.4    container_name: redis-3    restart: always    network_mode: "host"    volumes:      - /opt/docker/redis-cluster/redis-3/data:/data      - /opt/docker/redis-cluster/redis-3/redis.conf:/usr/local/etc/redis/redis.conf    command: ["redis-server", "/usr/local/etc/redis/redis.conf"]  # redis4配置  redis4:    image: daocloud.io/library/redis:6.0.4    container_name: redis-4    restart: always    network_mode: "host"    volumes:      - /opt/docker/redis-cluster/redis-4/data:/data      - /opt/docker/redis-cluster/redis-4/redis.conf:/usr/local/etc/redis/redis.conf    command: ["redis-server", "/usr/local/etc/redis/redis.conf"]  # redis5配置  redis5:    image: daocloud.io/library/redis:6.0.4    container_name: redis-5    restart: always    network_mode: "host"    volumes:      - /opt/docker/redis-cluster/redis-5/data:/data      - /opt/docker/redis-cluster/redis-5/redis.conf:/usr/local/etc/redis/redis.conf    command: ["redis-server", "/usr/local/etc/redis/redis.conf"]  # redis6配置  redis6:    image: daocloud.io/library/redis:6.0.4    container_name: redis-6    restart: always    network_mode: "host"    volumes:      - /opt/docker/redis-cluster/redis-6/data:/data      - /opt/docker/redis-cluster/redis-6/redis.conf:/usr/local/etc/redis/redis.conf    command: ["redis-server", "/usr/local/etc/redis/redis.conf"]

启动容器,执行命令:

#启动容器docker-compose -f xxx.yaml up -d

Docker-Compose如何搭建Redis集群

5.开启集群

随便找一个容器进入,这里我选择redis-1进入。 在进入容器后,输入如下命令开启集群:

redis-cli --cluster create 192.168.66.180:6379 \192.168.66.180:6380 \192.168.66.180:6381 \192.168.66.180:6382 \192.168.66.180:6383 \192.168.66.180:6384 \--cluster-replicas 1

Docker-Compose如何搭建Redis集群

出现下图即为成功。

Docker-Compose如何搭建Redis集群

6.测试

使用redis-cli命令,连接集群中任意节点。(随便找一台能ping通集群所在IP的电脑,这里我用的本机进行测试)

6.1 查看节点属性

redis-cli -c -h 192.168.66.180 -p 6379192.168.66.180:6379> cluster info

显示为如下图,即为集群健康状态

Docker-Compose如何搭建Redis集群

6.2 查看节点信息

cluster nodes

Docker-Compose如何搭建Redis集群

注意看图中的slave,master,myself等关键字。

Docker-Compose如何搭建Redis集群

6.3 插入一个值

192.168.66.180:6379> set test 'hello world'-> Redirected to slot [6918] located at 192.168.66.180:6380OK192.168.66.180:6380>

Docker-Compose如何搭建Redis集群

注意:这里根据切片自动切换到了该数据分片所在的节点上,所以下面可以看到连接的节点变为了192.168.1.4:6380

get test

168.66.180:6379> set test 'hello world'-> Redirected to slot [6918] located at 192.168.66.180:6380OK192.168.66.180:6380> get test"hello world"192.168.66.180:6380>

这里因为就是在该数据所在分片上进行的查询,所以连接节点没有改变。

7.添加密码:

7.1 编辑redis.conf文件

#为redis.conf文件添加如下配置。这里设置密码为123456masterauth 123456requirepass 123456

7.2 编辑docker-compose.yml文件

#为docker-compose.yml中每个容器添加如下配置:environment:  - REDISCLI_AUTH=123456

7.3 连接集群

redis-cli -c -h 192.168.66.180 -p 6379 -a 123456

“Docker-Compose如何搭建Redis集群”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

--结束END--

本文标题: Docker-Compose如何搭建Redis集群

本文链接: https://www.lsjlt.com/news/353305.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • c#文本框只读属性怎么设置
    c# 文本框只读属性的设置 问题:如何设置 C# 文本框的只读属性? 回答: 要设置文本框的只读属性,可以使用 ReadOnly 属性。 详细解释: ReadOnly 属性是一个布尔值属...
    99+
    2024-05-14
    c#
  • 如何使用 Golang ORM 工具与数据库交互?
    使用 gorm orm 工具与数据库交互,可通过以下步骤轻松实现:安装和初始化(1)、定义模型(2)、建立映射(3)、创建记录(4)、读取记录(5)、更新记录(6)、删除记录(7)、事务...
    99+
    2024-05-14
    golang orm mysql git iphone
  • c++中double与float的区别
    c++++ 中 double 与 float 的区别 在 C++ 中,double 和 float 都是浮点数类型,但它们在精度、范围和内存占用方面存在差异。 精度: double:双...
    99+
    2024-05-14
    c++ 内存占用
  • 如何在 Golang 中处理数据库错误?
    在 go 中处理数据库错误的步骤包括:使用专门的 go mysql 驱动程序。实现 error 接口以创建自定义错误。检测错误,记录足够的信息,并基于错误类型执行适当的恢复操作。 如何...
    99+
    2024-05-14
    golang 数据库错误 mysql git 数据丢失
  • c++中int怎么转string
    在 c++ 中将 int 转换为 string 的方法有:使用 to_string() 函数直接转换。使用 stringstream 类。使用 sprintf() 函数。 如何在 C+...
    99+
    2024-05-14
    c++
  • 优化 C++ 服务器架构以提高吞吐量
    优化 c++++ 服务器吞吐量策略:线程池:预先创建线程池,快速响应请求。非阻塞 i/o:在等待 i/o 时执行其他任务,提升吞吐量。http/2:使用二进制协议,支持多路复用和内容压缩...
    99+
    2024-05-14
    优化 服务器架构 c++
  • 使用 C++ 堆分配器管理服务器架构中的内存
    使用 c++++ 堆分配器管理服务器内存可提高性能和稳定性。堆分配器负责分配和释放动态内存,跟踪空闲/已分配内存元数据。在服务器架构中,它用于分配应用程序对象、缓冲区和数据结构。选择堆分...
    99+
    2024-05-14
    c++ 内存管理 并发访问
  • c#怎么获取字符串中的数字
    从 c# 字符串中提取数字的方法有五种:正则表达式、循环和 char.isdigit()、int.tryparse()、string.split() 和 int.parse()、linq...
    99+
    2024-05-14
    git c#
  • C++ 异常处理在服务器架构中的最佳实践
    c++++ 异常处理在服务器架构的最佳实践:定义清晰的异常层次结构,使用自定义异常类型封装相关信息。使用异常安全函数,及时在适当范围内处理异常。提供有意义的错误消息,帮助用户了解错误并采...
    99+
    2024-05-14
    c++ 异常处理
  • c#怎么拼接字符串
    在 c# 中拼接字符串有三种方法:使用加法(+)运算符、string.concat() 方法和 stringbuilder 类。最简单的方法是使用 + 运算符将字符串连接起来,...
    99+
    2024-05-14
    c#
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作