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的利用 ...
随机推荐
- XStream类对象把List<javaBean>()转成json数据
[省市联动] Servlet端: XStream把list转成json数据 //JSONArray-->变成数组/集合[] //JSONObject-->变成简单的数据{name:ayee ...
- PWA全称Progressive Web App,即渐进式WEB应用?
一个 PWA 应用首先是一个网页, 可以通过 Web 技术编写出一个网页应用. 随后添加上 App Manifest 和 Service Worker 来实现 PWA 的安装和离线等功能解决了哪些问题 ...
- Kerberos与各大组件的集成
1. 概述 Kerberos可以与CDH集成,CDH里面可以管理与hdfs.yarn.hbase.yarn.kafka等相关组件的kerberos凭证.但当我们不使用CDH的时候,也需要了解hdfs. ...
- websocket使用nginx代理后连接频繁打开和关闭
前几天开发了一个功能,使用websocket向前台发送消息,与前端联调时一切正常,但是发布到环境出现如下报错: 发现404,无法找到连接,突然想到环境上是走nginx代理的,应该是nginx没有配置代 ...
- 如果在拦截请求中,我想拦截get方式提交的方法,怎么配置?
可以在@RequestMapping注解里面加上method=RequestMethod.GET.
- Spring配置连接池和 Dao 层使用 jdbcTemplate
1.Spring 配置 c3p0 连接池 (1)导入jar包(Maven项目) <dependency> <groupId>com.mchange</groupId> ...
- mybatis的TypeHandler 的使用
今天看了别人的mybatis的教学视频,自己手写了一个简单的自定义的TypeHandler,有些细节记录一下. 1.定义自己的TypeHandler,代码如下: package com.example ...
- 配置sublime text 3来编写Markdown
如何使用sublime text 3编写Markdown 编写markdown的编辑器无论客户端还是在线的都有很多,这里将sublime text3作为markdown的编辑器,需要进行一些配置. ...
- BMZCTF phar???
pchar??? 补充知识点 开始这题之前我们先补充一个知识点 phar 的文件包含 和上面类似先创建一个phar 标准包,使用 PharData 来创建,然后添加文件进去phar里面. 然后在文件包 ...
- 数字电路的多路复用(MUX)
学习文章:https://mp.weixin.qq.com/s/1pfLfvkAPyhEMLvfnyDy0g 最基本--2选1的MUX结构: 可以看作是:assign Y=S?B:A; 下面使用MUX ...