在docker容器下安装Mysql8集群(一主一从)

2024-02-27 08:59

本文主要是介绍在docker容器下安装Mysql8集群(一主一从),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1,Mysql8基本配置参考:https://blog.csdn.net/Dumbass_baba/article/details/122563901?spm=1001.2014.3001.5501

2,安装完两台Mysql8后,选定一个mysql8为master,连接上master,添加(从机)slave权限,命令如下:

#添加一个slave用户,%表示不限ip,mysql_native_password表示mysql8之前的密码加密方式,
#mysql8之后用caching_sha2_password加密,防止报错,所以用mysql_native_password。
ALTER USER 'slave'@'%' IDENTIFIED WITH mysql_native_password BY '123456';grant replication slave,replication client on *.* to 'slave'@'%';

3,查看主机状态

show master status;

 

4,通过数据卷方式新增配置文件my.cnf。

4.1,master配置文件

[mysqld]
##设置server_id,同一局域网中需要唯一
server_id=101
##指定不需要同步的数据库名称
binlog-ignore-db=mysql,mysql_long
##开启二进制日志功能
log-bin=mall-mysql-bin
##设置二进制日志使用内存大小(事务)
binlog_cache_size=1M
##设置使用二进制的日志格式(mixed,statement,row)
binlog_format=mixed
##二进制日志过期清理时间。默认为0,表示不自动清理
expire_logs_days=7
##跳过主从赋值中遇到的所有错误或指定类型的错误,避免salve端复制中断
##如:1062错误是指一些主键重复,1032错误因为主从数据库数据不一致
slave_skip_errors=1062

4.2,slave配置文件

[mysqld]
##同一局域网中需要唯一
server_id=102
##指定不需要同步的数据库名称
binlog-ignore-db=mysql,mysql_long
##开启二进制日志功能
log-bin=mall-mysql-slave1-bin
##设置二进制日志使用内存大小(事务)
binlog_cache_size=1M
##设置使用二进制的日志格式(mixed,statement,row)
binlog_format=mixed
##二进制日志过期清理时间。默认为0,表示不自动清理
expire_logs_days=7
##跳过主从赋值中遇到的所有错误或指定类型的错误,避免salve端复制中断
##如:1062错误是指一些主键重复,1032错误因为主从数据库数据不一致
slave_skip_errors=1062
##relay_log配置中继日志
relay_log=mall-mysql-relay-bin
##log_slave_updates表示slave将复制事件写进自己的二进制日志
log_slave_updates=1
##slave设置为只读(具有super权限的用户除外)
read_only=1

5,重启两台mysql8

docker restart 容器ID

6,连接mysql8从机,与master进行绑定

参数含义:

master_host:宿主机的IP。

master_user:Mysql8主机中的自定义授权用户。

master_password:Mysql8主机中的自定义授权用户的密码。

master_port:Mysql8主机的端口号。

master_log_file:3步骤中查出来的file字段值。

master_log_pos:3步骤中查出来的position字段值(开始复制数据的位置)。

master_connect_retry:连接失败重试的时间,单位秒。


change master to master_host='124.223.68.234',master_user='slave',master_password='123456',master_port=3310,master_log_file='mall-mysql-bin.000002',master_log_pos=156,master_connect_retry=30;

7,查看从机的状态

show slave status \G;

8,开启主从同步

start slave;

9,测试是否配置成功

连接mysql主机,进行数据库操作,完成后连接从机,观察从机是否复制了主机的数据。


 

这篇关于在docker容器下安装Mysql8集群(一主一从)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/751890

相关文章

使用docker搭建嵌入式Linux开发环境

《使用docker搭建嵌入式Linux开发环境》本文主要介绍了使用docker搭建嵌入式Linux开发环境,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1、前言2、安装docker3、编写容器管理脚本4、创建容器1、前言在日常开发全志、rk等不同

MySQL8 密码强度评估与配置详解

《MySQL8密码强度评估与配置详解》MySQL8默认启用密码强度插件,实施MEDIUM策略(长度8、含数字/字母/特殊字符),支持动态调整与配置文件设置,推荐使用STRONG策略并定期更新密码以提... 目录一、mysql 8 密码强度评估机制1.核心插件:validate_password2.密码策略级

RabbitMQ 延时队列插件安装与使用示例详解(基于 Delayed Message Plugin)

《RabbitMQ延时队列插件安装与使用示例详解(基于DelayedMessagePlugin)》本文详解RabbitMQ通过安装rabbitmq_delayed_message_exchan... 目录 一、什么是 RabbitMQ 延时队列? 二、安装前准备✅ RabbitMQ 环境要求 三、安装延时队

linux系统上安装JDK8全过程

《linux系统上安装JDK8全过程》文章介绍安装JDK的必要性及Linux下JDK8的安装步骤,包括卸载旧版本、下载解压、配置环境变量等,强调开发需JDK,运行可选JRE,现JDK已集成JRE... 目录为什么要安装jdk?1.查看linux系统是否有自带的jdk:2.下载jdk压缩包2.解压3.配置环境

Redis中哨兵机制和集群的区别及说明

《Redis中哨兵机制和集群的区别及说明》Redis哨兵通过主从复制实现高可用,适用于中小规模数据;集群采用分布式分片,支持动态扩展,适合大规模数据,哨兵管理简单但扩展性弱,集群性能更强但架构复杂,根... 目录一、架构设计与节点角色1. 哨兵机制(Sentinel)2. 集群(Cluster)二、数据分片

Python库 Django 的简介、安装、用法入门教程

《Python库Django的简介、安装、用法入门教程》Django是Python最流行的Web框架之一,它帮助开发者快速、高效地构建功能强大的Web应用程序,接下来我们将从简介、安装到用法详解,... 目录一、Django 简介 二、Django 的安装教程 1. 创建虚拟环境2. 安装Django三、创

linux安装、更新、卸载anaconda实践

《linux安装、更新、卸载anaconda实践》Anaconda是基于conda的科学计算环境,集成1400+包及依赖,安装需下载脚本、接受协议、设置路径、配置环境变量,更新与卸载通过conda命令... 目录随意找一个目录下载安装脚本检查许可证协议,ENTER就可以安装完毕之后激活anaconda安装更

Jenkins的安装与简单配置过程

《Jenkins的安装与简单配置过程》本文简述Jenkins在CentOS7.3上安装流程,包括Java环境配置、RPM包安装、修改JENKINS_HOME路径及权限、启动服务、插件安装与系统管理设置... 目录www.chinasem.cnJenkins安装访问并配置JenkinsJenkins配置邮件通知

Win10安装Maven与环境变量配置过程

《Win10安装Maven与环境变量配置过程》本文介绍Maven的安装与配置方法,涵盖下载、环境变量设置、本地仓库及镜像配置,指导如何在IDEA中正确配置Maven,适用于Java及其他语言项目的构建... 目录Maven 是什么?一、下载二、安装三、配置环境四、验证测试五、配置本地仓库六、配置国内镜像地址

Python安装Pandas库的两种方法

《Python安装Pandas库的两种方法》本文介绍了三种安装PythonPandas库的方法,通过cmd命令行安装并解决版本冲突,手动下载whl文件安装,更换国内镜像源加速下载,最后建议用pipli... 目录方法一:cmd命令行执行pip install pandas方法二:找到pandas下载库,然后