将之前的mysql主从配置整理了一下放到博客上,方便下次使用
我们在ubuntu中已经有安装一台mysql了,现在使用docker安装另外一台mysql
获取mysql的镜像,主从同步尽量保证多台mysql的版本相同
sudo docker image pull mysql:5.7.22 # 5.7.22是版本号,保持mysql版本相同 或 sudo docker load -i mysql_docker_5722.tar
运行mysql docker镜像,需要在宿主机中建立文件目录用于mysql容器保存数据和读取配置文件。
在家目录中(/home/python)中创建目录,将mysql的配置文件放到此目录中
cd ~ mkdir mysql_slave cd mysql_slave mkdir data cp /etc/mysql/mysql.conf.d ./ -r
我们要将docker运行的mysql作为slave来运行,开启前需要修改配置文件。
编辑 ~/mysql_slave/mysql.conf.d/mysqld.cnf 文件,修改
port = 8306 general_log = 0 server-id = 2
我们让此台mysql运行在8306端口上,且mysql编号为2
创建docker容器
docker run --name mysql-slave -e MYSQL_ROOT_PASSWORD=mysql -d --network=host -v /home/python/mysql_slave/data:/var/lib/mysql -v /home/python/mysql_slave/mysql.conf.d:/etc/mysql/mysql.conf.d mysql:5.7.22
测试,在ubuntu中使用mysql命令尝试连接docker容器中的mysql
mysql -uroot -p -h 127.0.0.1 --port=8306
如果在设置主从同步前,主服务器上已有大量数据,可以使用mysqldump进行数据备份并还原到从服务器以实现数据的复制。
在主服务器Ubuntu上进行备份,执行命令:
mysqldump -uroot -p --all-databases --lock-all-tables > ~/master_db.sql
在docker容器中导入数据
mysql -uroot -p -h127.0.0.1 --port=8306 < ~/master_db.sql
编辑设置mysqld的配置文件,设置log_bin和server-id
sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf
重启mysql服务
sudo service mysql restart
登入主服务器Ubuntu中的mysql,创建用于从服务器同步数据使用的帐号
mysql –uroot –p GRANT REPLICATION SLAVE ON *.* TO 'slave'@'%' identified by 'slave'; FLUSH PRIVILEGES;
获取主服务器的二进制日志信息
SHOW MASTER STATUS;
File为使用的日志文件名字,Position为使用的文件位置,这两个参数须记下,配置从服务器时会用到。
进入docker中的mysql
mysql -uroot -p -h 127.0.0.1 --port=8306
执行
change master to master_host='127.0.0.1', master_user='slave', master_password='slave',master_log_file='mysql-bin.000006', master_log_pos=590; # master_log_pos 为查询出来的Position #master_lof_file 为查询出来的file
启动slave服务器,并查看同步状态
start slave; show slave status \G