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主从复制,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对小牛知识库网站的支持!
本文向大家介绍mysql 5.7 docker 主从复制架构搭建教程,包括了mysql 5.7 docker 主从复制架构搭建教程的使用技巧和注意事项,需要的朋友参考一下 分享mysql 5.7 docker 主从复制架构搭建教程,供大家参考,具体内容如下 环境版本: MySQL : 5.7.13 Docker : 1.11.2 CentOS : 7.1 1.先在两个物理机上分别安装两个MyS
本文向大家介绍基于Docker的MySQL主从复制环境搭建的实现步骤,包括了基于Docker的MySQL主从复制环境搭建的实现步骤的使用技巧和注意事项,需要的朋友参考一下 1. 前言 之前的程序架构可能是这样的一种形式: 当程序体量扩大后,我们进行扩展,可能会扩展多个后台服务实例,但数据库还是只有一个,所以系统的瓶颈还是在数据库上面,所以这次的主要任务就是对数据库进行扩展,主要形式为:扩展多台数据
本文向大家介绍如何快速使用mysqlreplicate搭建MySQL主从,包括了如何快速使用mysqlreplicate搭建MySQL主从的使用技巧和注意事项,需要的朋友参考一下 简介 mysql-utilities工具集是一个集中了多种工具的合集,可以理解为是DBA的工具箱,本文介绍利用其中的mysqlreplicate工具来快速搭建MySQL主从环境。 HE1:192.168.1.248 sl
我正在使用docker容器来编译一段代码,我不一定要将其docker化。我已使用必要的构建工具设置了一个映像,但我希望以某种方式将编译后的文件从容器中取出,而无需使用docker cp container:/file host/file命令。换句话说,我希望自动化这个过程,以便在构建完成后,将生成的文件复制到主机。 Dockerfile
我正在考虑使用Docker在持续集成(CI)服务器上构建我的依赖项,这样我就不必在代理本身上安装所有的运行时和库。 为了实现这一点,我需要将在容器中构建的构建构件复制回主机中。有可能吗?
问题内容: 我正在开发服务,并在那里使用docker compose来旋转诸如postgres,redis,elasticsearch之类的服务。我有一个基于RubyOnRails的Web应用程序,并从所有这些服务中进行读写操作。 这是我的 我可以在此网络中ping容器 到目前为止,一切都很好。现在我想在主机上的Rails应用程序上运行ruby,但是能够像目前这样使用url访问postgres实例