docker redis安装配置(使用docker搭建redis主从的方法步骤)
docker redis安装配置
使用docker搭建redis主从的方法步骤 一、构建 Docker 环境
1、创建 dockerfile
FROM centos:latest RUN groupadd -r redis && useradd -r -g redis redis RUN yum -y update && yum -y install epel-release && yum -y install redis && yum -y install net-tools EXPOSE 6379
2、构建镜像
docker build -t docker-test .
3、查看当前镜像
docker iamges REPOSITORY TAG IMAGE ID CREATED SIZE docker-test latest ccebd30e466a 12 minutes ago 396MB centos latest 470671670cac 7 weeks ago 237MB
4、查看docker默认的网络类型
docker network ls NETWORK ID NAME DRIVER SCOPE a43e79987e98 bridge bridge local 6b73067403dc host host local b8ad4981e57e none null local
5、创建自定义网络类型
docker network create --subnet=172.10.0.0/16 haveyb-network
二、搭建 Redis 主从
1、创建 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 -a
CONTAINER ID IMAGE COMMAND CREATED dc9344bbd25f docker-test "/bin/bash" 2 minutes ago STATUS PORTS NAMES Up 2 minutes 0.0.0.0:6380->6379/tcp redis-master
注:查看某个网络下容器的ip地址
docker network inspect haveyb-network
3、创建 redis-slave1、redis-slave2 容器
docker run -itd --name redis-slave1 --net haveyb-network -p 6381:6379 --ip 172.10.0.3 docker-test docker run -itd --name redis-slave2 --net haveyb-network -p 6382:6379 --ip 172.10.0.4 docker-test
4、配置 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-cli auth yourPasswordSettings
5、配置 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-cli
6、配置 redis-slave2
同配置 redis-slave1
7、在redis -cli中执行 `info replication` 可以查看主从信息
redis-master
127.0.0.1:6379> info replication # Replication role:master connected_slaves:2 slave0:ip=172.10.0.3,port=6379,state=online,offset=3105,lag=1 slave1:ip=172.10.0.4,port=6379,state=online,offset=3105,lag=1 master_replid:a3a43b1957bc5b9f18cb3004301990085e49b0d1 master_replid2:0000000000000000000000000000000000000000 master_repl_offset:3105 second_repl_offset:-1 repl_backlog_active:1 repl_backlog_size:1048576 repl_backlog_first_byte_offset:1 repl_backlog_histlen:3105 127.0.0.1:6379>
redis-slave1
127.0.0.1:6379> info replication # Replication role:slave master_host:172.10.0.2 master_port:6379 master_link_status:up master_last_io_seconds_ago:1 master_sync_in_progress:0 slave_repl_offset:3203 slave_priority:100 slave_read_only:1 connected_slaves:0 master_replid:a3a43b1957bc5b9f18cb3004301990085e49b0d1 master_replid2:0000000000000000000000000000000000000000 master_repl_offset:3203 second_repl_offset:-1 repl_backlog_active:1 repl_backlog_size:1048576 repl_backlog_first_byte_offset:1 repl_backlog_histlen:3203 127.0.0.1:6379>
8、在 redis-master 中写入key,redis-slave1 和 redis-slave2 已经可以获取了
到此这篇关于使用docker搭建redis主从的方法步骤的文章就介绍到这了,更多相关docker搭建redis主从内容请搜索开心学习网以前的文章或继续浏览下面的相关文章希望大家以后多多支持开心学习网!
- docker容器管理技巧(Docker容器编排实现过程解析)
- docker显示出错应用图标怎么处理(docker 命令报异常permission denied的解决方案)
- 容器之间的通信docker(Docker容器互访的三种方法)
- docker保存容器的配置文件(docker cp 拷贝文件 和 进入容器的操作)
- 远程给docker容器执行命令(Docker命令让普通用户能够执行的实现)
- docker 部署netcore(关于Jenkins + Docker + ASP.NET Core自动化部署的问题避免踩坑)
- docker离线安装步骤(Docker安装FastDFS的方法步骤)
- docker进入容器的方法(docker容器里面的root权限获取方法)
- dockerfile映射目录(Dockerfile中ENTRYPOINT 和 CMD的区别说明)
- docker停止删除所有容器方法(Docker stop停止/remove删除所有容器)
- docker删除多个镜像命令(Docker 彻底删除私有库镜像的操作)
- docker-compose 原理(详解docker compose 用法)
- docker 容器运行的数据在哪里(docker容器的几种存储详解)
- docker-compose怎么被执行的(Docker Compose一键ELK部署的方法实现)
- dockerfile构建镜像两种方式(通过Dockerfile构建Docker镜像的方法步骤)
- docker线上部署流程(Docker部署Rancher的方法无坑)
- 不走心的古装造型 舒畅 毁容式 出演,萧蔷雷出新高度(不走心的古装造型)
- 嘉南传 第22集(嘉南传第22集)
- 哪版孙悟空最萌 黄渤躺萌了(哪版孙悟空最萌)
- 融入小人物的喜怒哀乐,黄渤饰演的角色为什么让人观看时欲罢不能(融入小人物的喜怒哀乐)
- 《极限挑战》深访都市夜归人,夜间打工者体验,黄磊录完憔悴了(极限挑战深访都市夜归人)
- Google 推出了一个游戏生成器,让不会编程的你也能自己设计游戏(推出了一个游戏生成器)
热门推荐
- django学生管理系统搭建(Django实现学员管理系统)
- 云服务器最低配置可以吗(云服务器内存怎么选择?)
- 如何去阿里云解析域名(利用Python+阿里云实现DDNS动态域名解析的方法)
- css选择器优先级
- textarea 高度自适应
- mysql不兼容问题(解决mysql 组合AND和OR带来的问题)
- mysqlinnodb数据存储格式(MySQL InnoDB ReplicaSet副本集简单介绍)
- sqlserver技术文档(sql server2016里面的json功能浅析)
- 织梦联动菜单的下拉代码(dede5.7 动态导航下拉菜单的实现代码)
- sqlserver删除表的第一行数据(sql server删除前1000行数据的方法实例)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9