很久没有记录了,今天有时间就记录一下最近安装遇到的问题

liunx安装docker这个是前提,就不多过述

1 准备两台服务器

10.104.13.139

10.104.13.140

2 确保liunx安装的docker正常运行的

ps:最好提前关闭防火墙 或者提前开放对应端口 不然同步会失败的 关闭防火墙后记得重启docker 不然docker容器会启动失败的

1:查看防火状态
systemctl status firewalld
service iptables status 2:暂时关闭防火墙
systemctl stop firewalld
service iptables stop 3:永久关闭防火墙
systemctl disable firewalld
chkconfig iptables off
// 重启命令
systemctl restart docker

3 后续就正式的开始安装了

docker run -d -p 4406:3306 \
--name mysql-4406 \
--privileged=true \
-v /app/mysql-4406/log:/var/log/mysql \
-v /app/mysql-4406/data:/var/lib/mysql \
-v /app/mysql-4406/conf:/etc/mysql/conf.d \
-e MYSQL_ROOT_PASSWORD=root \
mysql:8.0.35 --lower_case_table_names=1 命令解释:
-d: 后台运行容器,并返回容器ID
-p 3311:3306 :将容器的3306端口映射到宿主机3310端口
-e MYSQL_ROOT_PASSWORD=123456 :配置数据库连接密码
-v /home/mysql/node-2/config:/etc/mysql/ :将配置文件夹挂载到宿主机
–name mysql01(02):将容器命名为 mysql01(02)
lower_case_table_names=1 不区分大小写

查看容器是否正常启动

docker ps

如果启动失败 需要查看容器的日志

docker ps -a
docker logs 容器id

后续就是在挂载的目录创建MySQL的配置文件了

cd /app/mysql-4406/conf
vim my.cnf // 编辑插入配置 就不再过多解释 基本的配置 [mysqld]
log-error=/var/log/mysqld.log
server_id=101
binlog-ignore-db=mysql
log-bin=mall-mysql-bin
binlog_cache_size=1M
binlog_format=mixed
expire_logs_days=7
slave_skip_errors=1062

编辑保存后,需要重启容器使其配置文件生效

-- 重启镜像
docker ps
docker restart id

下一步就是进入到MySQL中创建同步的用户信息并赋予其权限

--进入镜像登陆MySQL
docker exec -it id /bin/bash
mysql -uroot -p --创建同步账号
CREATE USER 'slave'@'%' IDENTIFIED BY 'slave';
--给账号赋权限
GRANT ALL ON *.* TO 'slave'@'%' WITH GRANT OPTION;
-- 刷新权限
FLUSH PRIVILEGES; --查看master日志信息
show master status;

完成后,master库的操作就完成了,后续就不要再动主库了,记住show master status;显示的值,slave同步用到

主要是用到 file和position的值

4 安装slave数据库 和master安装差不多

docker run -d -p 4407:3306 \
--name mysql-4407 \
--privileged=true \
-v /app/mysql-4407/log:/var/log/mysql \
-v /app/mysql-4407/data:/var/lib/mysql \
-v /app/mysql-4407/conf:/etc/mysql/conf.d \
-e MYSQL_ROOT_PASSWORD=root \
mysql:8.0.35 --lower_case_table_names=1
// 查询容器是否启动
docker ps
// 创建配置文件
cd /app/mysql-4407/conf
vim my.cnf [mysqld]
server_id=102
binlog-ignore-db=mysql
log-bin=mall-mysql-slave1-bin
binlog_cache_size=1M
binlog_format=mixed
expire_logs_days=7
slave_skip_errors=1062
relay_log=mall-mysql-relay-bin
log_slave_updates=1
read_only=1

-- 重启镜像
docker restart id

--进入镜像登陆MySQL

ocker exec -it id /bin/bash
mysql -uroot -p change master to master_host='10.104.13.139', master_user='slave', master_password='slave', master_port=4406, master_log_file='mall-mysql-bin.000001', master_log_pos=875, master_connect_retry=30, get_master_public_key=1; 解释:
get_master_public_key 密码加密方式
CHANGE MASTER TO MASTER_HOST='主机的IP地址',
MASTER_USER='slave'(刚刚配置的用户名),
MASTER_PASSWORD='123456'(刚刚授权的密码),
master_port=主机开放的端口 我这里是3310端口,
MASTER_LOG_FILE='mysql-bin.具体数字'
MASTER_LOG_POS=具体值(之前的Position);
master_connect_retry=30, 在主服务器宕机或连接丢失的情况下,从服务器线程重新尝试连接主服务器之前睡眠的秒数。如果主服务器.info文件中的值可以读取则优先使用。如果未设置, 默认值为60 --启动同步
start slave;
--查看同步状态
show slave status \G;
Slave_IO_Running: Yes
Slave_SQL_Running: Yes --都为yes 就是成功了

--如果失败了  Slave_IO_Running: NO 重复擦操作下面的步骤

stop slave;
reset slave all;
change master to master_host='10.104.13.139', master_user='slave', master_password='slave', master_port=4406, master_log_file='mall-mysql-bin.000001', master_log_pos=875, master_connect_retry=30, get_master_public_key=1;
-- 需要检查 slave 的权限 或者 master_log_file master_log_pos 信息是否对上
start slave;
show slave status \G;

到这里主从复制就完成了,后续就是验证了,这里就不多说了

#登录master库

#创建数据库testdb,使用默认字符集
create database test11; #在slave中查看是否有test11库
show database;

打完收工,欢迎交流。2024-05-25 14:53:25

docker安装MySQL8.0.35主从复制(实战保姆级)的更多相关文章

  1. docker安装Mysql8.0并挂载外部配置和数据

    环境 CentOS Linux release 7.7.1908 (Core) 拉取Mysql8.0 镜像 docker pull mysql:8.0.18 创建挂载目录 mkdir -p /home ...

  2. Docker安装MySQL8.0

    环境 CentOS 7.5 Docker 1.13.1 MySQL 8.0.16 安装 拉取镜像 默认拉取最新版本的镜像 $ docker pull mysql 如果要指定版本,使用下面的命令 $ d ...

  3. Docker 安装mysql8.0

    1. 下载Mysql的Docker镜像: $ docker search mysql (搜索mysql镜像) $ docker pull mysql (下载mysql镜像,默认最新版本) 2. 运行镜 ...

  4. Docker部署Mysql8.0.20并配置主从复制

    1. Linux安装Mysql8.0.20并配置主从复制(一主一从,双主双从)   Linux安装Mysql8.0.20并配置主从复制(一主一从,双主双从) 2. 前提准备 # 创建主从数据库文件夹 ...

  5. Centos7安装MySQL8.0 - 操作手册

    MySQL 8 正式版 8.0.11 已发布,官方表示 MySQL 8 要比 MySQL 5.7 快 2 倍,还带来了大量的改进和更快的性能! 一.  Mysql8.0版本相比之前版本的一些特性 1) ...

  6. CentOS7安装MySQL8.0小计

    之前讲配置文件和权限的时候有很多MySQL8的知识,有同志说安装不太一样,希望发个文,我这边简单演示一下 1.环境安装 下载MySQL提供的CentOS7的yum源 官方文档:<https:// ...

  7. docker安装MySQL8,目录挂载、配置用户名密码、忽略表名大小写、连接数、特殊字符、时区

    原文:docker安装MySQL8,目录挂载.配置用户名密码.忽略表名大小写.连接数.特殊字符.时区 一.环境配置 1.系统:centos7.3 2.docker版本:Docker version 1 ...

  8. CentOS7.5 上使用 bundle 文件安装 MySQL8.0 MySQL5.0

    CentOS7.5 上使用 bundle 文件安装 MySQL8.0 MySQL5.0 CentOS7.5 环境 [root@instance-fjii60o3 ~]# rpm -qi centos- ...

  9. 【MySQL】Docker搭建MySQL8.0

    目录 Docker搭建MySQL8.0 目的: 1.安装Docker 2.查看docker镜像 3.拉取mysql官方镜像 4. 查看目前的镜像 5.运行docker mysql镜像 6.查看目前运行 ...

  10. CentOS7.4 源码安装MySQL8.0

    MySQL 8 正式版 8.0.11 已发布,官方表示 MySQL 8 要比 MySQL 5.7 快 2 倍,还带来了大量的改进和更快的性能! 以下为本人2018.4.23日安装过程的记录.整个过程大 ...

随机推荐

  1. 解密prompt系列27. LLM对齐经验之如何降低通用能力损失

    前面我们已经聊过众多指令微调的方案,这一章我们重点讨论下如何注入某一类任务或能力的同时,尽可能不损失模型原有的通用指令理解能力.因为在下游或垂直领域应用中,我们设计的推理任务风格或形式,往往很难通过p ...

  2. 重新整理数据结构与算法(c#)—— 算法套路动态规划算法[二十六]

    前言 动态规划算法的核心思想是:将大问题划分为小问题进行解决,从而一步步获取最优解的处理算法. 这样一听和分治算法有点相似啊. 是的,分治算法也是将大问题分为小问题,但是他们毕竟不同,不同之处在什么地 ...

  3. Scratch3之AI集成 - flappy bird AI版本

    AI神秘且有趣,我们一个经典的游戏flappy bird集成AI,实现自训练成长的聪明的笨鸟.先上效果: 初始化的笨鸟拥有分身,每个分身都有自我学习功能,根据自己的移动轨迹和得分情况进行汇总,进行新一 ...

  4. 第六課-Channel Study For TCP Listener & HTTP Listener & Web Service Listener About Response Handler

    经过前面章节的课程,对Mirth Connect在系统集成与数据交互中的使用有了一个大概的了解:大家一定有个疑惑,Mirth Connect如何组织响应消息并返回给调用者?今天我们就来继续深入讲解Re ...

  5. TiDB Vector 抢先体验之用 TiDB 实现以图搜图

    本文首发自 TiDB 社区专栏:https://tidb.net/blog/0c5672b9 前言 最早知道 TiDB 要支持向量化的消息应该是在23年10月份左右,到第一次见到 TiDB Vecto ...

  6. MySQL统计信息不准导致的性能问题

    简介: 统计信息不准导致错误的执行计划,引发性能问题 表的统计信息错误导致优化器选择错误的执行计划. 一个客户的性能优化案例: 没有修改数据库实例的任何配置参数以及业务代码没有变更的情况下,一条 sq ...

  7. 说说关系型数据库与Serverless

    简介: 看到如今Serverless在云计算行业喷薄欲出的态势,像极了<星星之火,可以燎原>中的描述:虽然不能预测未来的发展和变化,但对于云计算来说这是个相对确定的方向.本文从产业界和学术 ...

  8. 业界首个机密计算容器运行时—Inclavare Containers正式进入CNCF!

    ​简介: Inclavare Containers 通过云原生计算基金会(CNCF)TOC 投票正式成为 CNCF 官方沙箱项目. 作者|彦荣 ​ 2021 年 9月 15 日,Inclavare C ...

  9. 深入理解云计算OpenAPI体系

    ​简介: 就云计算的API来看,当前并没有类似POSIX这样的API标准,基本上各大厂商各自为政.当然,有一些业界主流标准例如OAS获得多数云厂商的支持,但云厂商本身的API却往往由于历史原因.技术路 ...

  10. [Docker] 使 Volume 独立于容器运行时的方式 - 让容器引擎去处理

    在单纯使用 run 命令运行一个容器时,通常会使用 -v 挂载的方式来实现宿主机数据卷映射到容器内. 使用命令: $ docker run --name mysql-con -v /my/custom ...