使用Linux环境下的Docker搭建MySQL主从集群

简介: 本文记录了一次在Linux环境下的Docker搭建MySQL主从集群的过程。主从集群读写分离,从节点只负责读取数据。

使用Linux环境下的Docker搭建MySQL主从集群

1. 系统及软件版本

虚拟机版本:VMware Workstation Pro 17

虚拟机镜像版本:CentOS Linux release 7.9.2009 (Core)

Docker:ce-24.0.5

MySQL:5.7

2. 搭建过程
2.1 主机搭建

首先使用Docker拉取MySQL5.7的镜像文件:

docker pull mysql:5.7

启动MySQL主机:

docker run --name mysql_master \ # 设置容器名称
> -e MYSQL_ROOT_PASSWORD=123 \ # 设置MySQL中root用户的初始密码
> -v /root/mysql_master/log:/var/log/mysql \ # 目录挂载,宿主机不存在的目录会自动创建
> -v /root/mysql_master/data:/var/lib/mysql \
> -v /root/mysql_master/conf:/etc/mysql/conf.d \
> -dp 3316:3306 \ # 分离模式启动,指定容器内端口3306暴露到外部的3316
> mysql:5.7 # 指定镜像

更改MySQL主机的配置:

# 在宿主机上挂载的目录中新建my.cnf配置文件
vim /root/mysql_master/conf/my.cnf
# my.cnf
# 指定字符编码,避免中文数据输入报错
[client]
default_character_set=utf8

[mysql]
default_character_set=utf8

[mysqld]
character_set_server=utf8

server_id=01 # MySQL服务器的唯一ID。主从复制中,每个服务器都需要唯一的ID
binlog-ignore-db=mysql # 指定要忽略的数据库名称。MySQL将忽略“mysql"数据库,不将其写入二进制日志文件
log-bin=master-log-bin # 启用二进制日志记录,并指定二进制文件的名称
binlog_cache_size=1M # 指定二进制日志缓存的大小
binlog_format=mixed # 指定二进制日志格式
expire_logs_days=7 # 指定二进制日志文件的过期时间
slave_skip_error=1062 # 指定从节点在复制期间要跳过的错误代码。1062错误表示在从节点上执行的操作与主节点上的操作冲突。跳过1062可让从节点避免部分sql语句错误而终止后续复制操作。

配置文件写完之后,需要重启MySQL主机:

docker restart mysql_master

之后需要进入主机为后面的从机创建一个用户:

docker exec -it mysql_master /bin/bash
root@xxx:/#mysql -uroot -p
Enter password: # 验证密码后进入MySQL命令行

# 创建用户语法:CREATE USER 'username'@'hostname' IDENTIFIED BY 'password'
# hostname为%表示可以从任何主机连接到此MySQL服务器
mysql> CREATE USER 'slave'@'%' IDENTIFIED BY '123456';

# 对slave用户进行授权
# REPLICATION SLAVE 表示允许该用户作为MySQL从节点连接到主节点
# REPLICTAION CLIENT 表示允许该用户使用MySQL复制客户端工具,即复制数据的权限
mysql> GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* to 'slave'@'%';

到这里主服务器的配置已完成。

2.2 从机搭建

同样的,先开启一个MySQL容器,注意参数不要写错:

docker run --name mysql_slave \
> -e MYSQL_ROOT_PASSWORD=123 \
> -v /root/mysql_slave/log:/var/log/mysql \
> -v /root/mysql_slave/data:/var/lib/mysql \
> -v /root/mysql_slave/conf:/etc/mysql/conf.d \
> -dp 3316:3306 \
> mysql:5.7

配置MySQL文件:

vim /root/mysql_slave/conf/my.cnf
# my.cnf
[client]
default_character_set=utf8

[mysql]
default_character_set=utf8

[mysqld]
character_set_server=utf8

server_id=02
binlog-ignore-db=mysql
log-bin=slave-log-bin
binlog_cache_size=1M
binlog_format=mixed
expire_logs_days=7
slave_skip_error=1062
relay_log=relay-log-bin # 启用中继日志记录,并指定中继日志文件的名称。在主从复制中,中继日志在从节点记录从主节点接收到的二进制事件
log_slave_updates=1 # 表示从机是否将复制事件写入二进制日志,当从机为其他从机的主机时,此配置需要为1或on
read_only=1 # 表示从节点是只读的

重启从机,让配置生效:

docker restart mysql_slave

打开从机的命令行:

docker exec -it mysql_slave /bin/bash

在主机界面查看二进制日志文件名称以及其开始位置:

root@xxx:/#mysql -uroot -p
Enter password:

mysql> show master status;
+-----------------------+----------+--------------+------------------+-------------------+
| File                  | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+-----------------------+----------+--------------+------------------+-------------------+
| master-log-bin.000001 |      617 |              | mysql            |                   |
+-----------------------+----------+--------------+------------------+-------------------+

然后在从机的界面中指定主机:

mysql> change master to master_host='ip', # 输入主机ip
> master_user='slave',master_password='123456', # 刚刚在主机中为从机创建的用户信息
> master_port=3316, # 主机端口
> master_log_file='master-log-bin.000001', master_log_pos=617, # 刚刚在主机查看的二进制文件信息
> master_connect_retry=30, # 连接失败重试等待时间
> master_retry_count=3; # 重试次数

设置完从机指定的主机后,可在从机界面查看从机的相关状态:

mysql> show slave status \G;
*************************** 1. row ***************************
               Slave_IO_State: 
                  Master_Host: 192.168.6.201
                  Master_User: slave
                  Master_Port: 3316
                Connect_Retry: 30
              Master_Log_File: master-log-bin.000001
          Read_Master_Log_Pos: 617
               Relay_Log_File: relay-log-bin.000001
                Relay_Log_Pos: 4
        Relay_Master_Log_File: master-log-bin.000001
             Slave_IO_Running: No
            Slave_SQL_Running: No # 两个NO说明主从复制还没有开始

开启主从复制,此时上面的两个NO变成了YES:

mysql> start slave;

到此MySQL的主从搭建完成,可以通过在主机中写入数据,再在从节点进行数据读取进行测试。


相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
7天前
|
关系型数据库 MySQL Linux
Linux环境下MySQL数据库自动定时备份实践
数据库备份是确保数据安全的重要措施。在Linux环境下,实现MySQL数据库的自动定时备份可以通过多种方式完成。本文将介绍如何使用`cron`定时任务和`mysqldump`工具来实现MySQL数据库的每日自动备份。
22 3
|
7天前
|
监控 关系型数据库 MySQL
Linux环境下MySQL数据库自动定时备份策略
在Linux环境下,MySQL数据库的自动定时备份是确保数据安全和可靠性的重要措施。通过设置定时任务,我们可以每天自动执行数据库备份,从而减少人为错误和提高数据恢复的效率。本文将详细介绍如何在Linux下实现MySQL数据库的自动定时备份。
20 3
|
30天前
|
关系型数据库 MySQL Linux
Docker安装Mysql5.7,解决无法访问DockerHub问题
当 Docker Hub 无法访问时,可以通过配置国内镜像加速来解决应用安装失败和镜像拉取超时的问题。本文介绍了如何在 CentOS 上一键配置国内镜像加速,并成功拉取 MySQL 5.7 镜像。
273 2
Docker安装Mysql5.7,解决无法访问DockerHub问题
|
14天前
|
关系型数据库 MySQL Docker
docker环境下mysql镜像启动后权限更改问题的解决
在Docker环境下运行MySQL容器时,权限问题是一个常见的困扰。通过正确设置目录和文件的权限,可以确保MySQL容器顺利启动并正常运行。本文提供了多种解决方案,包括在主机上设置正确的权限、使用Dockerfile和Docker Compose进行配置、在容器启动后手动更改权限以及使用 `init`脚本自动更改权限。根据实际情况选择合适的方法,可以有效解决MySQL容器启动后的权限问题。希望本文对您在Docker环境下运行MySQL容器有所帮助。
28 1
|
19天前
|
消息中间件 Linux RocketMQ
在Red Hat Enterprise Linux 9上使用Docker快速安装并部署
通过以上步骤,你可以在Red Hat Enterprise Linux 9上使用Docker快速安装并部署RocketMQ。这种方法不仅简化了安装过程,还提供了一个灵活的环境来管理和扩展消息队列系统。RocketMQ作为一款高性能的分布式消息系统,通过Docker可以实现快速部署和高效管理。
46 2
|
20天前
|
消息中间件 Linux RocketMQ
在Red Hat Enterprise Linux 9上使用Docker快速安装并部署
通过以上步骤,你可以在Red Hat Enterprise Linux 9上使用Docker快速安装并部署RocketMQ。这种方法不仅简化了安装过程,还提供了一个灵活的环境来管理和扩展消息队列系统。RocketMQ作为一款高性能的分布式消息系统,通过Docker可以实现快速部署和高效管理。
29 3
|
23天前
|
关系型数据库 MySQL Linux
基于阿里云服务器Linux系统安装Docker完整图文教程(附部署开源项目)
基于阿里云服务器Linux系统安装Docker完整图文教程(附部署开源项目)
189 2
|
1月前
|
Oracle 关系型数据库 MySQL
Mysql(1)—简介及Windows环境下载安装
MySQL 是一个流行的关系型数据库管理系统(RDBMS),基于 SQL 进行操作。它由瑞典 MySQL AB 公司开发,后被 Sun Microsystems 收购,现为 Oracle 产品。MySQL 是最广泛使用的开源数据库之一,适用于 Web 应用程序、数据仓库和企业应用。
53 2
|
8天前
|
SQL 关系型数据库 MySQL
go语言数据库中mysql驱动安装
【11月更文挑战第2天】
22 4
|
6天前
|
SQL 关系型数据库 MySQL
12 PHP配置数据库MySQL
路老师分享了PHP操作MySQL数据库的方法,包括安装并连接MySQL服务器、选择数据库、执行SQL语句(如插入、更新、删除和查询),以及将结果集返回到数组。通过具体示例代码,详细介绍了每一步的操作流程,帮助读者快速入门PHP与MySQL的交互。
19 1