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

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. WPF/MVVM模式入门教程(一):简介与规范

    引用:https://www.cnblogs.com/flh1/p/12421652.html 什么是MVVM模式? MVVM的全称是--Model.View.ViewModel,翻译过来就是:模型. ...

  2. RabbitMQ 05 直连模式-Spring Boot操作

    Spring Boot集成RabbitMQ是现在主流的操作RabbitMQ的方式. 官方文档:https://docs.spring.io/spring-amqp/docs/current/refer ...

  3. org.xml.sax.SAXParseException; lineNumber: 11;

    org.xml.sax.SAXParseException; lineNumber: 11; 点击clean  然后再启动

  4. Filebeat 日志采集工具安装

    Filebeat 是比较轻量的日志采集工具,对于一些简单的采集任务可以直接使用 Filebeat 采集,同时也支持很多的方式输出,可以输出至 Kafka.Elasticsearch.Redis 等,下 ...

  5. 力扣239(Java)- 滑动窗口最大值(困难)

    题目: 给你一个整数数组 nums,有一个大小为 k 的滑动窗口从数组的最左侧移动到数组的最右侧.你只可以看到在滑动窗口内的 k 个数字.滑动窗口每次只向右移动一位. 返回 滑动窗口中的最大值 . 示 ...

  6. OpenYurt 开箱测评 | 一键让原生 K8s 集群具备边缘计算能力

    作者| 郑超 阿里云高级开发工程师 随着物联网技术以及 5G 技术的高速发展,将云计算的能力延伸至边缘设备端,并通过中心进行统一交付.管控,已成为云计算的重要发展趋势.为服务更多开发者把握这一趋势,5 ...

  7. Timing:在线自习室快速搭建

    ​通过超低延迟的音视频通信技术.视频连麦.弱网传输算法,快速搭建自习场景,提升自习效率. 客户简介 ​ 氪细胞主打产品Timing,是国内最早推出,也是规模最大的在线自习室,是新一代的教育与社交融合平 ...

  8. 直播回顾:准确性提升到 5 秒级,ssar 独创的 load5s 指标有多硬核?| 龙蜥技术

    ​简介: 你还在为分析机器负载高而苦恼?这款 ssar 工具独创 load5s 指标精准定位超硬核. 编者按:本文整理自龙蜥SIG技术周会,作者闻茂泉,阿里云计算平台事业部SRE运维专家,是龙蜥社区跟 ...

  9. 如何进行基于Anolis OS的企业级Java应用规模化实践?|龙蜥技术

    ​简介:提供了7×24小时的专属钉钉或者电话支持,响应时间保证到在业务不可用情况下10分钟响应,业务一般的问题在一小时可以获得响应,主要城市可以两小时内得到到达现场的服务. 本文作者郁磊,是Java语 ...

  10. 从技术到科学,中国AI向何处去?

    ​简介: 如果从达特茅斯会议起算,AI已经走过65年历程,尤其是近些年深度学习兴起后,AI迎来了空前未有的繁荣.不过,最近两年中国AI热潮似乎有所回落,在理论突破和落地应用上都遇到了挑战,外界不乏批评 ...