Docker极简入门:使用Docker-Compose 搭建redis集群
为了构建一个集群,我们首先要让 redis 启用集群模式
一个简单的配置文件如下redis.conf
# redis.conf file
port 6379
cluster-enabled yes
cluster-config-file nodes.conf
cluster-node-timeout 5000
appendonly yes
因为是在单机上演示,所以我们得修改 port 防止冲突
比如我们要创建3主5副的集群,那么这八个 redis 实例启动的时候就应该用不同的端口(7000,7001...7007),这样能防止冲突。
.
├── 7000
│ └── redis.conf
├── 7001
│ └── redis.conf
├── 7002
│ └── redis.conf
├── 7003
│ └── redis.conf
├── 7004
│ └── redis.conf
├── 7005
│ └── redis.conf
├── 7006
│ └── redis.conf
├── 7007
│ └── redis.conf
./7000/redis.conf
中的 port 设置成7000,依此类推./7007/redis.conf
中的 port 应该设置成7007
往事俱备,只需运行redis-server ./redis.conf
命令即可,当然你需要到依次启动八个 redis server
for i in `seq 7000 7007`;
do
exec redis-server ./${i}/redis.conf &
done
redis-cli --cluster create\
127.0.0.1:7000 127.0.0.1:7001 127.0.0.1:7002 127.0.0.1:7003\
127.0.0.1:7004 127.0.0.1:7005 127.0.0.1:7006 127.0.0.1:7007\
--cluster-replicas 1
这样整个集群就搭建好了,你可以选择运行在 port 7000-7007中的任意一个 servr 登录,然后去执行一些你喜欢的命令验证一下[狗头]
使用Docker-Compose构建集群
现在让我们来明确一下流程,首先我们需要启动八个 redis server 实例,然后运行 redis-cli --cluster create
命令创建集群,这意味着我们需要创建一个 docker network 使得集群成员能够互相通讯
创建一个 network 也很简单
networks:
redis-network:
name: redis-network
## 使用网桥
driver: bridge
ipam:
driver: default
## 指定网段,需要注意不能与已有的 docker network 相冲突
config:
- subnet: 172.18.0.0/24
还记得之前命令行是如何启动集群的吗?最后需要运行命令redis-cli --cluster create
,整个集群才算成功创建,那在 yml 文件中该怎么写呢?
我们可以借助 depends_on
来告诉 docker 当前的 service 依赖其他的 service
具体的细节请看完整的yml文件
## redis.conf
port 6379
cluster-enabled yes
cluster-config-file nodes-redis.conf
cluster-node-timeout 5000
appendonly yes
appendfilename "appendonly-redis.aof"
version: "3.7"
networks:
redis-network:
name: redis-network
driver: bridge
ipam:
driver: default
config:
- subnet: 172.18.0.0/24
services:
redis-cluster:
image: redis:6-alpine
command: 'redis-cli --cluster create
172.18.0.11:6379 172.18.0.12:6379 172.18.0.13:6379 172.18.0.14:6379
172.18.0.15:6379 172.18.0.16:6379 172.18.0.17:6379 172.18.0.18:6379
--cluster-yes --cluster-replicas 1'
networks:
- redis-network
depends_on:
- redis1
- redis2
- redis3
- redis4
- redis5
- redis6
- redis7
- redis8
redis1:
image: redis:6-alpine
container_name: redis1
command: redis-server /usr/local/etc/redis/redis.conf
networks:
redis-network:
ipv4_address: 172.18.0.11
expose:
- 6379
volumes:
- $PWD/docker-data/redis1:/data
- $PWD/docker-config/redis.conf:/usr/local/etc/redis/redis.conf
redis2:
image: redis:6-alpine
container_name: redis2
command: redis-server /usr/local/etc/redis/redis.conf
networks:
redis-network:
ipv4_address: 172.18.0.12
expose:
- 6379
volumes:
- $PWD/docker-data/redis2:/data
- $PWD/docker-config/redis.conf:/usr/local/etc/redis/redis.conf
redis3:
image: redis:6-alpine
container_name: redis3
command: redis-server /usr/local/etc/redis/redis.conf
networks:
redis-network:
ipv4_address: 172.18.0.13
expose:
- 6379
volumes:
- $PWD/docker-data/redis3:/data
- $PWD/docker-config/redis.conf:/usr/local/etc/redis/redis.conf
redis4:
image: redis:6-alpine
container_name: redis4
command: redis-server /usr/local/etc/redis/redis.conf
networks:
redis-network:
ipv4_address: 172.18.0.14
expose:
- 6379
volumes:
- $PWD/docker-data/redis4:/data
- $PWD/docker-config/redis.conf:/usr/local/etc/redis/redis.conf
redis5:
image: redis:6-alpine
container_name: redis5
command: redis-server /usr/local/etc/redis/redis.conf
networks:
redis-network:
ipv4_address: 172.18.0.15
expose:
- 6379
volumes:
- $PWD/docker-data/redis5:/data
- $PWD/docker-config/redis.conf:/usr/local/etc/redis/redis.conf
redis6:
image: redis:6-alpine
container_name: redis6
command: redis-server /usr/local/etc/redis/redis.conf
networks:
redis-network:
ipv4_address: 172.18.0.16
expose:
- 6379
volumes:
- $PWD/docker-data/redis6:/data
- $PWD/docker-config/redis.conf:/usr/local/etc/redis/redis.conf
redis7:
image: redis:6-alpine
container_name: redis7
command: redis-server /usr/local/etc/redis/redis.conf
networks:
redis-network:
ipv4_address: 172.18.0.17
expose:
- 6379
volumes:
- $PWD/docker-data/redis7:/data
- $PWD/docker-config/redis.conf:/usr/local/etc/redis/redis.conf
redis8:
image: redis:6-alpine
container_name: redis8
command: redis-server /usr/local/etc/redis/redis.conf
networks:
redis-network:
ipv4_address: 172.18.0.18
expose:
- 6379
volumes:
- $PWD/docker-data/redis8:/data
- $PWD/docker-config/redis.conf:/usr/local/etc/redis/redis.conf
最后不要忘记了最基本的命令
sudo docker-compose up # 在当前命令下运行,启动集群
sudo docker-compose down # 关闭集群的同时会将 docker-network也一并删除
如何与集群通信
# 登录任意一个节点执行命令即可,集群会根据key的哈希值,将你的命令重定位
sudo docker exec -it redis5 redis-cli -p 6379
set foo bar
sudo docker exec -it redis1 redis-cli -p 6379
get foo
# output bar
参考
Docker极简入门:使用Docker-Compose 搭建redis集群的更多相关文章
- .Net Core in Docker极简入门(下篇)
Tips:本篇已加入系列文章阅读目录,可点击查看更多相关文章. 目录 前言 开始 Docker-Compose 代码修改 yml file up & down 镜像仓库 最后 前言 上一篇[. ...
- 这次一定要教会你搭建Redis集群和MySQL主从同步(非Docker)
前言 一直都想自己动手搭建一个Redis集群和MySQL的主从同步,当然不是依靠Docker的一键部署(虽然现在企业开发用的最多的是这种方式),所以本文就算是一个教程类文章吧,但在动手搭建之前,会先聊 ...
- 从零开始学习docker之在docker中搭建redis(集群)
docker搭建redis集群 docker-compose是以多容器的方式启动,非常适合用来启动集群 一.环境准备 云环境:CentOS 7.6 64位 二.安装docker-compose #需要 ...
- docker搭建redis集群和Sentinel,实现故障转移
0.引言 公司开发需要用到redis,虽然有运维自动搭建,还是记录下如何搭建redis集群和Sentinel. 采用的是vagrant虚拟机+docker的方式进行搭建. 搭建思路: 首先是借鉴下其他 ...
- docker搭建redis集群
一.简介 docker作为一个容器技术,在搭建资源隔离性服务上具有很大的优势,在一台服务器上可以启动多个docker容器,感觉每个在容器里面部署的服务就像是部署在不同的服务器上.此次基于docker以 ...
- Mac 搭建 Redis 集群
date: 2020-09-24 16:24:00 updated: 2020-09-24 17:30:00 Mac 搭建 Redis 集群 参考文档 摘要 安装docker brew cask in ...
- Windows下 搭建redis集群
Windows下搭建redis集群教程 一,redis集群介绍 Redis cluster(redis集群)是在版本3.0后才支持的架构,和其他集群一样,都是为了解决单台服务器不够用的情况,也防止了主 ...
- 基于 twemproxy 搭建 redis 集群
概述 由于单台redis服务器的内存管理能力有限,使用过大内存redis服务器的性能急剧下降,且服务器发生故障将直接影响大面积业务.为了获取更好的缓存性能及扩展型,我们将需要搭建redis集群来满足需 ...
- Windows下搭建Redis集群
Redis集群: 如果部署到多台电脑,就跟普通的集群一样:因为Redis是单线程处理的,多核CPU也只能使用一个核, 所以部署在同一台电脑上,通过运行多个Redis实例组成集群,然后能提高CPU的利用 ...
随机推荐
- Java并发机制(6)--阻塞队列
Java并发编程:阻塞队列整理自:博客园-海子-http://www.cnblogs.com/dolphin0520/p/3933404.html 1.什么是阻塞队列 除了同步容器(Hashtable ...
- 什么时候用断言(assert)?
答:断言在软件开发中是一种常用的调试方式,很多开发语言中都支持这种机制.一般来说,断言用于保证程序最基本.关键的正确性.断言检查通常在开发和测试时开启.为了保证程序的执行效率,在软件发布后断言检查通常 ...
- java常用方法集合
1.获取当前日期 // 获取当前日期 public Date getDate(int num) { Calendar cal = new GregorianCalendar(); cal.setTim ...
- volatile 能使得一个非原子操作变成原子操作吗?
一个典型的例子是在类中有一个 long 类型的成员变量.如果你知道该成员变量 会被多个线程访问,如计数器.价格等,你最好是将其设置为 volatile.为什么? 因为 Java 中读取 long 类型 ...
- resin服务之一---安装及部署
参考网站: http://caucho.com/ http://www.oschina.net/p/resin http://caucho.com/resin-4.0/admin/starting-r ...
- 更改IE中的jdk版本
一丶打开IE设置: 快捷键:Ctrl+Shift+Alt+S 二丶在设置中调设已经安装的jdk版本(前提已安装):
- PCB基础知识(一)
在电子行业有一个关键的部件叫做PCB(printed circuit board,印刷电路板).这是一个太基础的部件,导致很多人都很难解释到底什么是PCB.这篇文章将会详细解释PCB的构成,以及在PC ...
- 记录axios高效率并发的方法
// 首先我的请求是统一管理 方便创建拦截器 export function login(parameter) { return axios({ url: api.Login, ...
- 关于小程序websocket全套解决方案,Nginx代理wss
需求对话 提问 我在本地web能够使用ws协议去链接websocket,但是小程序不能使用. 回答 由于小程序使用的是SSL加密协议,所以需要使用wss.这里wss与ws的关系就相当于https于ht ...
- jquery 常用选择器和方法以及遍历(超详细)
jQuery 常用选择器和和方法 学习总结 一.JQuery 介绍 1. 什么是 jQuery 2. jQuery 版本介绍 3. jQuery 文件介绍 二.jQuery 对象 1. jQuery ...