时间:2021-05-19
1、创建 dockerfile
FROM centos:latestRUN groupadd -r redis && useradd -r -g redis redisRUN yum -y update && yum -y install epel-release && yum -y install redis && yum -y install net-toolsEXPOSE 63792、构建镜像
docker build -t docker-test .3、查看当前镜像
docker iamgesREPOSITORY TAG IMAGE ID CREATED SIZEdocker-test latest ccebd30e466a 12 minutes ago 396MBcentos latest 470671670cac 7 weeks ago 237MB4、查看docker默认的网络类型
docker network lsNETWORK ID NAME DRIVER SCOPEa43e79987e98 bridge bridge local6b73067403dc host host localb8ad4981e57e none null local5、创建自定义网络类型
docker network create --subnet=172.10.0.0/16 haveyb-network1、创建 redis-master 容器
docker run -itd --name redis-master --net haveyb-network -p 6380:6379 --ip 172.10.0.2 docker-test参数解释:
-i: 以交互模式运行容器,通常与 -t 同时使用
-t: 为容器重新分配一个伪输入终端,通常与 -i 同时使用
-d: 后台运行容器,并返回容器ID;
--name: 为创建的容器命名
--net: 指定网络模式(这里指定刚才创建的自定义网络模式)
-p: 端口映射,格式为:主机(宿主)端口:容器端口
--ip: 为容器制定一个固定的ip
后面再指定一下使用的镜像(这里使用的就是刚才创建的镜像 docker-test)
2、查看运行中的容器
docker ps -aCONTAINER ID IMAGE COMMAND CREATEDdc9344bbd25f docker-test "/bin/bash" 2 minutes ago STATUS PORTS NAMESUp 2 minutes 0.0.0.0:6380->6379/tcp redis-master注:查看某个网络下容器的ip地址
docker network inspect haveyb-network3、创建 redis-slave1、redis-slave2 容器
docker run -itd --name redis-slave1 --net haveyb-network -p 6381:6379 --ip 172.10.0.3 docker-testdocker run -itd --name redis-slave2 --net haveyb-network -p 6382:6379 --ip 172.10.0.4 docker-test4、配置 redis-master 容器
(1)进入redis-master 容器
docker exec -it redis-master bash注:退出容器 `exit`
(2)修改redis.conf 配置文件
vi /etc/redis.conf(3)修改参数 bind 127.0.0.1 为 0.0.0.0
bind 0.0.0.0(4)设置主redis 密码
requirepass YourPasswordSettings(5)启动主redis
redis-server /etc/redis.conf &(6)redis-cli
redis-cliauth yourPasswordSettings5、配置 redis-slave1
(1)进入redis-slave1 容器
docker exec -it redis-slave1 bash(2)修改redis.conf 配置文件
vi /etc/redis.conf(3)修改参数 bind 127.0.0.1 为 0.0.0.0
bind 0.0.0.0(4)设置 masterauth,添加以下代码(主redis设置密码后,从redis连接需要此参数验权)
masterauth yourPasswordSettings(5)设置 slaveof (设置主 redis 的 ip 和 port)
slaveof 172.10.0.2 6379(5)启动从redis
redis-server /etc/redis.conf &(6)redis 客户端
redis-cli6、配置 redis-slave2
同配置 redis-slave1
7、在redis -cli中执行 `info replication` 可以查看主从信息
redis-master
127.0.0.1:6379> info replication# Replicationrole:masterconnected_slaves:2slave0:ip=172.10.0.3,port=6379,state=online,offset=3105,lag=1slave1:ip=172.10.0.4,port=6379,state=online,offset=3105,lag=1master_replid:a3a43b1957bc5b9f18cb3004301990085e49b0d1master_replid2:0000000000000000000000000000000000000000master_repl_offset:3105second_repl_offset:-1repl_backlog_active:1repl_backlog_size:1048576repl_backlog_first_byte_offset:1repl_backlog_histlen:3105127.0.0.1:6379>redis-slave1
127.0.0.1:6379> info replication # Replicationrole:slavemaster_host:172.10.0.2master_port:6379master_link_status:upmaster_last_io_seconds_ago:1master_sync_in_progress:0slave_repl_offset:3203slave_priority:100slave_read_only:1connected_slaves:0master_replid:a3a43b1957bc5b9f18cb3004301990085e49b0d1master_replid2:0000000000000000000000000000000000000000master_repl_offset:3203second_repl_offset:-1repl_backlog_active:1repl_backlog_size:1048576repl_backlog_first_byte_offset:1repl_backlog_histlen:3203127.0.0.1:6379>8、在 redis-master 中写入key,redis-slave1 和 redis-slave2 已经可以获取了
到此这篇关于使用docker搭建redis主从的方法步骤的文章就介绍到这了,更多相关docker搭建redis主从内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
前言本篇文章记录我使用docker-compose以及dockerfile来构建基于binlog的MySQL主从环境。如果你严格按照文中的步骤进行配置,相信很快
本文介绍了docker搭建redis集群的环境搭建,分享给大家,废话不多说,具体如下:下载镜像dockerpullredis准备配置文件mkdir/home/d
Ubuntu搭建基于Docker的LNMP+Redis的开发环境服务器环境:Ubuntu14.041.安装Docker1.1执行update命令,和服务器同步软
一、Redis主从同步原理1.1Redis主从同步的过程配置好slave服务器连接的master后,slave会建立和master的连接,然后发送sync命令。
前面我们使用的DockerHub是由Docker官方提供的,我们也可以搭建自己的Docker,搭建方式也很容器,因为Docker官方已经将Docker注册服务器