Docker创建Mysql镜像,搭建主从复制环境 前言一、编写Dockerfile制作mysql镜像编写Dockerfile文件编写mysql_file文件:编写run.sh文件build M
学习黑马的mysql时,在主从复制、分库分表、读写分离等阶段需要多台服务器,于是尝试用docker创建镜像搭建主从复制环境。
本文基于Centos7搭建mysql镜像。
参考大佬文章: link
由于需要进行编辑操作,所以需要额外下载vim
FROM centos:7RUN yum localinstall -y https://repo.mysql.com//mysql80-commUnity-release-el7-1.noarch.rpmRUN yum install -y yum-utilsRUN yum install -y vimRUN sed -i 's/gpGCheck=1/gpgcheck=0/g' /etc/yum.repos.d/mysql-community.repo && sed -i 's/gpgcheck=1/gpgcheck=0/g' /etc/yum.repos.d/mysql-community-source.repoRUN yum install -y mysql-server mysql mysql-develCOPY run.sh /run.shRUN chmod 777 /run.sh && /run.shEXPOSE 3386CMD ["mysqld","--user=root"]
#! /bin/bashrm -rf /var/lib/mysqlmysqld --initialize-insecurechown -R mysql:mysql /var/lib/mysqlmysqld --user root &sleep 5mysqladmin -u root passWord 123457
docker build -f ./mysql_file -t mybuildsql .
docker run -d --name mysql1 --privileged=true mybuildsql /usr/sbin/init
docker exec -it mysql1 /bin/bash
mysql -uroot -p123456
至此centos7+MySQL镜像搭建完成,可以使用ifconfig查看ip地址。
此步骤具体操作可以查看黑马MySQL视频
主库使用宿主机,从库使用上述创建的MySQL镜像。
首先关闭服务器防火墙或者开放3306端口,本文采用关闭服务器防火墙。
systemctl stop firewalld
在etc/my.cnf中增加以下语句
server-id=1read-only=0
systemctl restart mysqld
mysql -uroot -pflush privileges;create user 'itcast'@'%';GRANT REPLICATioN SLAVE ON *.* TO 'itcast'@'%';
此坐标在配置从库时需要
show master status;
进入上述创建的MySQL镜像,并启动MySQL
在etc/my.cnf中增加以下语句
server-id=2read-only=1
systemctl restart mysqld
change replication source to source_host='**.**.**.**',source_user='itcast',source_log_file='mysql-bin.000008',source_log_pos=723;
source_host为主库所在服务器的ip,source_log_file与source_log_pos为之前在主库中查询的二进制日志得到相关信息。
start replica;
show replica status;
配置成功
show databases;
show databases;
开始时主库、从库均只有MySQL的初始数据库。
create database db01;use db01;create table tb_user(-> id int(11) primary key not null auto_increment,-> name varchar(50) not null,-> sex varchar(1)-> )engine=innodb default charset=utf8mb4;insert into tb_user values(1,'Tom','1'),(2,'Trigger','0'),(3,'Dawn','1');
主库创建数据库并插入数据,从库的数据库同步。
从库中数据已同步,同理在主库中修改数据,在从库中也会进行同步,至此数据库的主从复制环境成功搭建。
来源地址:https://blog.csdn.net/qq_45248909/article/details/130008108
--结束END--
本文标题: docker创建MySQL镜像,搭建主从复制环境
本文链接: https://lsjlt.com/news/420218.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-10-23
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0