使用Docker容器搭建MySql主从复制

 更新时间:2016年11月22日 11:07:20   作者:zhangchao19890805  
这篇文章主要介绍了使用Docker容器搭建MySql主从复制的相关资料,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下

1. 编写主MySQL的Docker文件

新建文件夹,命名为MySQL-master-v1。在文件夹mysql-master-v1中新建文件Dockerfile和master.cnf。笔者推荐使用的编辑器是Visual Studio Code。利用编辑器将这两个文件的编码设置成UTF-8。因为本文介绍安装到Linux系统下,所以笔者建议读者把换行符设置成LF,以兼顾Linux操作系统。按照如下内容编写这两个文件。

Dockerfile

FROM mysql:5.7
# set timezone as china/shanghai
RUN cp /usr/share/zoneinfo/PRC /etc/localtime
# copy mysql config file
COPY master.cnf /etc/mysql/conf.d/
ENTRYPOINT ["docker-entrypoint.sh"]
EXPOSE 3306
CMD ["mysqld"]

master.cnf

user=root
password='123456'
[mysqld]
max_allowed_packet=8M
lower_case_table_names=1
character_set_server=utf8
max_connections=900
max_connect_errors=600
server-id=1
log-bin=mysql-bin
replicate-wild-do-table=db1.%
replicate-wild-do-table=db2.%
slow_query_log=1
long_query_time=1
log_error

2. 主MySQL的配置文件参数说明

解释一下master.cnf。

lower_case_table_names:忽略表名、列名等数据结构的大小写(注意:不是每行记录内容的大小写!)。

server-id=1: 表示此MySQL服务器是主服务器 。

log-bin:开启二进制记录。这是为了主从复制而做的设置。本文使用RBR(Row-Based Replication)模式。

replicate-wild-do-table:规定有哪些表可以从主服务器复制到从服务器。db1.%是指只要是数据库db1的表,就都可以复制到从服务器上。可以多条设置,来允许多个数据库。

没有使用replicate-do-db是因为replicate-do-db禁止跨数据库的访问。比如用户已经使用use db2;选择了数据库db2,用户还要执行update db1.t_student set c_name='stu_c' where c_id='1234c',那么就不能使用replicate-do-db。在编程的时候虽然程序员不会用到use,但是程序员有可能把连接mysql的url写成指定某个数据库或没有指定具体的数据库。即便没有指定数据库,使用replicate-do-db也是不允许的。

slow_query_log=1:开启慢查询日志。如果某一条SQL执行的时间超过long_query_time设置的秒数,那么就记录下来。记录文件路径可以使用show variables;命令,在变量名是slow_query_log_file下查找到具体的日志文件路径。

long_query_time=1:单位是秒。指如果某一条SQL语句执行时间超过1秒,就记录下来。必须开启慢查询日志了以后,此变量才能使用。

log_error:开启错误日志。show variables like 'log_error'; 就可以查询到日志文件的路径。mysql的Docker官方镜像如果设置别的取值会导致容器无法正常启动。

3. 生成并使用主MySQL的镜像

上传文件夹mysql-master-v1到Linux服务器上。为了便于说明,用服务器A来指代这台服务器。笔者的Linux版本是Ubuntu14.04。通过cd命令进入目录mysql-master-v1。然后输入以下命令来编译镜像:

docker build -t zhangchao/mysql-master5.7:v1 .

注意不要落下行末尾最后一个点。

根据编译好的镜像,生成新的容器:

docker run --name mysql-master \
-p 3306:3306 \
-v /zc/mysql-master/datadir:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD='123456' -d zhangchao/mysql-master5.7:v1

使用MySQL的客户端连接MySQL主服务器,笔者使用的是MySQL Workbench。执行如下命令:

show master status;

记录下file和position。这里假设file是mysql-bin.000001,post是154。

4. 编写从MySQL的Docker文件

新建文件夹 mysql-slave-v1。仿照步骤1在文件夹 mysql-slave-v1下新建 Dockerfile 和 slave.cnf 两个文件。下面是这两个文件的内容。

Dockerfile

FROM mysql:5.7
# set timezone as china/shanghai
RUN cp /usr/share/zoneinfo/PRC /etc/localtime
# copy mysql config file
COPY slave.cnf /etc/mysql/conf.d/
ENTRYPOINT ["docker-entrypoint.sh"]
EXPOSE 3306
CMD ["mysqld"]

slave.cnf

[mysqldump]
user=root
password='123456'
[mysqld]
max_allowed_packet=8M
lower_case_table_names=1
character_set_server=utf8
max_connections=900
max_connect_errors=600
slow_query_log=1
long_query_time=1
log_error
# Regard this db as a slave
server-id=2

slave.cnf 文件中的 server-id=2 会把MySQL服务器设置成从服务器。

5. 生成并使用从MySQL的镜像

上传 mysql-slave-v1 到第二台服务器。用服务器B来指代这台服务器。

编译镜像:

docker build -t zhangchao/mysql-slave5.7:v1 .

利用新的镜像建立容器:

docker run --name mysql-slave \
-p 3306:3306 \
-v /zc/mysql-slave/datadir:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD='123456' -d zhangchao/mysql-slave5.7:v1

这时MySQL的主从服务器都在运行中,需要读者自行保证两边的数据相同。只有当两台服务器的数据都一样的时候,才能建立主从复制连接。

6. 把从MySQL连接到主MySQL上

使用客户端连接到MySQL从服务器,假定服务器A的IP是192.168.10.1。

执行如下命令:

change master to 
master_host='192.168.10.1',
master_user='root',
master_password='123456',
master_log_file='mysql-bin.000001',
master_log_pos=154;

待命令正常执行后,接着执行如下命令:

start slave;

这样就可以主从复制了。只要在主服务器的db1和db2数据库插入或修改数据,就可以自动复制到从服务器上了。

以上所述是小编给大家介绍的使用Docker容器搭建MySql主从复制,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

相关文章

  • Docker容器/bin/bash start.sh无法找到not found问题解决

    Docker容器/bin/bash start.sh无法找到not found问题解决

    最近在学习联系中遇到一个问题,百度后发现这个需求还是挺常见的,所以下面这篇文章主要给大家介绍了关于Docker容器/bin/bash start.sh无法找到not found问题的解决方法,需要的朋友可以参考下
    2022-08-08
  • 解决docker run后容器出现Exited (0)情况的问题

    解决docker run后容器出现Exited (0)情况的问题

    这篇文章主要介绍了解决docker run后容器出现Exited (0)情况的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-03-03
  • docker nginx(访问静态文件、访问共享目录、负载均衡)配置方式

    docker nginx(访问静态文件、访问共享目录、负载均衡)配置方式

    这篇文章主要介绍了docker nginx(访问静态文件、访问共享目录、负载均衡)配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2025-03-03
  • 从零搭建docker+jenkins+node.js自动化部署环境的方法

    从零搭建docker+jenkins+node.js自动化部署环境的方法

    这篇文章主要介绍了从零搭建docker+jenkins+node.js自动化部署环境的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-01-01
  • Docker利用busybox创建基础镜像(base image)

    Docker利用busybox创建基础镜像(base image)

    今天小编就为大家分享一篇关于Docker利用busybox创建基础镜像(base image),小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2018-12-12
  • docker打包前端项目的实现示例

    docker打包前端项目的实现示例

    本文介绍了如何将前端项目打包到Docker容器中,包括编写Dockerfile文件、创建镜像和容器以及解决部署过程中遇到的问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2024-09-09
  • Docker 文件系统-AUFS 原理介绍

    Docker 文件系统-AUFS 原理介绍

    这篇文章主要介绍了Docker 文件系统-AUFS原理,Docker 主要是基于 Namespace、cgroups 和联合文件系统这三大核心技术实现的,下文相关内容需要的小伙伴可以参考一下
    2022-04-04
  • 如何解决docker logs无法实时输出脚本打印的内容

    如何解决docker logs无法实时输出脚本打印的内容

    这篇文章主要介绍了如何解决docker logs无法实时输出脚本打印的内容问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-07-07
  • docker安装java环境的实现步骤

    docker安装java环境的实现步骤

    这篇文章主要介绍了docker安装java环境的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-12-12
  • docker pull mysql报missing signature key错误解决办法

    docker pull mysql报missing signature key错误解决办法

    这篇文章主要给大家介绍了关于docker pull mysql报missing signature key错误的解决办法,docker pull mysql命令用于从Docker Hub下载MySQL镜像,需要的朋友可以参考下
    2023-11-11

最新评论