龙空技术网

docker如何搭建mysql主从?

黑马程序员 487

前言:

而今大家对“mysql服务器搭建”大约比较看重,我们都需要了解一些“mysql服务器搭建”的相关知识。那么小编同时在网摘上汇集了一些有关“mysql服务器搭建””的相关资讯,希望看官们能喜欢,大家快快来学习一下吧!

目录:

1 Docker 搭建 mysql 主从1 下载 docker 镜像2 创建网络驱动3.1 主服务器搭建3.1.1 启动主服务器3.1.2 修改主服务器的配置4 从服务器搭建3.1.1 启动从服务器3.1.2 修改从服务器的配置

1 Docker 搭建 mysql 主从1 下载 docker 镜像

docker pull mysql

2 创建网络驱动

docker network create {网络名称} 创建专门用于容器之间通信的网络

作用: 创建 docker 容器的时候 通过 --network {网络名称} 可以方便在内部使用容器名称进行通信

docker network create cusnet

3.1 主服务器搭建3.1.1 启动主服务器

docker run -dit  --network cusnet --name mysql_master -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 mysql
3.1.2 修改主服务器的配置进入容器中docker exec -it mysql_master /bin/bash修改配置文件cd /etc/mysql

echo "[mysqld]" > my.cnf

echo "pid-file = /var/run/mysqld/mysqld.pid" >> my.cnf

echo "socket = /var/run/mysqld/mysqld.sock" >> my.cnf

echo "datadir = /var/lib/mysql" >> my.cnf

echo "secure-file-priv= NULL" >> my.cnf

echo "secure-file-priv= NULL" >> my.cnf

echo "log-bin=/var/run/mysqld/mysql-bin" >> my.cnf # [必须]启用二进制日志

echo "server-id=1" >> my.cnf # [必须]服务器唯一ID

set +H

echo "!includedir /etc/mysql/conf.d/" >> my.cnf创建用于复制的账号$ mysql -uroot -p123456

mysql> CREATE USER 'slave'@'%' IDENTIFIED BY '123456';

mysql> GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'slave'@'%';关闭容器重启 docker container stop mysql_master && docker container start mysql_master4 从服务器搭建3.1.1 启动从服务器

docker run -dit  --network cusnet --name mysql_slave -p 3307:3306 -e MYSQL_ROOT_PASSWORD=123456 mysql
3.1.2 修改从服务器的配置进入容器中docker exec -it mysql_slave /bin/bash修改配置文件cd /etc/mysql

echo "[mysqld]" > my.cnf

echo "pid-file = /var/run/mysqld/mysqld.pid" >> my.cnf

echo "socket = /var/run/mysqld/mysqld.sock" >> my.cnf

echo "datadir = /var/lib/mysql" >> my.cnf

echo "secure-file-priv= NULL" >> my.cnf

echo "secure-file-priv= NULL" >> my.cnf

echo "log-bin=/var/run/mysqld/mysql-bin" >> my.cnf # [必须]启用二进制日志

echo "relay_log=/var/run/mysqld/mysql-relay-bin" >> my.cnf

echo "server-id=2" >> my.cnf # [必须]服务器唯一ID

set +H

echo "!includedir /etc/mysql/conf.d/" >> my.cnf关闭容器重启 docker container stop mysql_slave && docker container start mysql_slave连接到 master$ mysql -uroot -p123456

mysql> show master status \G; ;; 这句话是查看 master 日志文件和当前的位置

mysql> CHANGE MASTER TO GET_MASTER_PUBLIC_KEY=1;

mysql> change master to MASTER_HOST='mysql_master',MASTER_USER='slave',MASTER_PASSWORD='123456',MASTER_LOG_FILE="mysql-bin.000001",MASTER_LOG_POS=156;

mysql> start slave; ;; 启动复制

mysql> show slave status \G; ;; 查看复制的状态如果报 (1872, 'Slave failed to initialize relay log info structure from the repository')执行 reset slave;

标签: #mysql服务器搭建 #mysql主主配置 #docker下载mysql镜像 #mysql建立主从 #springmysql主从