python中mysql主从同步配置的方法澳门新葡亰赌995577:

澳门新葡亰赌995577 12

4)配置从服务器slave (docker中的mysql)

进入docker中的mysql

mysql -uroot -pmysql -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_host:主服务器Ubuntu的ip地址
  • master_log_file:
    前面查询到的主服务器日志文件名
  • master_log_pos:
    前面查询到的主服务器日志文件位置

启动slave服务器,并查看同步状态

start slave;
show slave status \G

 

澳门新葡亰赌995577 1

 

 

 

从服务器配置:

1.把主服务器上导出的master_db.sql备份文件先同步到从服务器上,保证主从数据一致。

把master_db.sql先放到从库的服务器上(注意文件位置要和你打开终端的位置保持一致,比如都在桌面),然后执行如下命令:

mysql -uroot -pmysql <
master_db.sql

澳门新葡亰赌995577 2

此时从库服务器已经拥有跟主服务器一样的数据了,如下图所示:

澳门新葡亰赌995577 3

2.修改从服务器的配置文件my.ini

加上对应的server-id,要保证不能跟主服务器的server-id一样

澳门新葡亰赌995577 4

保持退出之后重启从服务器,如下图:

澳门新葡亰赌995577 5

3.连接到从服务器,进行同步工作

澳门新葡亰赌995577 6

输入如下指令:

change master to master_host='192.168.13.81', master_user='slave', master_password='slave',master_log_file='mysql-bin.000008', master_log_pos=582;

注意:需要修改的地方有3处,第一个ip地址改成自己主服务器的ip地址,第二个二进制文件要跟主服务器的一致,第三个是pos位置也要与主服务器一致。具体的值参见主服务器配置的第4步

4.开始同步

输入命令:start slave;

澳门新葡亰赌995577 7

5.查看同步状态

输入指令:show slave status
\G;

澳门新葡亰赌995577 8

当看到两个yes意味着同步成功。如果没有成功先检查一下主从是否可以ping通,如果主从可以正常通信的话,则从文档的“主服务器配置”的第4步开始把步骤再走一遍。

1)安装mysql

ubuntu中安装一台mysql了,docker安装另外一台mysql

获取mysql的镜像,主从同步尽量保证多台mysql的版本相同,我的ubuntu中存在的mysql是5.7.22版本,所以获取5.7.22版本的镜像为例:

docker image pull mysql:5.7.22
或
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 ./

 

将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

 

  • MYSQL_ROOT_PASSWORD 是创建mysql
    root用户的密码

测试,在ubuntu中使用mysql命令尝试连接docker容器中的mysql

mysql -uroot -pmysql -h 127.0.0.1 --port=8306

 

前情提要:

本文档以Ubuntu作为主服务器,Win7作为从服务器进行测试。要保证主从服务器之间能够互相通信(即能相互ping通)。

主服务器ip地址:192.168.13.81

澳门新葡亰赌995577 9

从服务器ip地址:192.168.13.82

澳门新葡亰赌995577 10

测试通信状况:

主可以ping通从:

澳门新葡亰赌995577 11

从可以ping通主:

澳门新葡亰赌995577 12