MySQL主从同步

MySQL主从同步:

主从同步使得数据可以从一个数据库服务器复制到其他服务器上,在复制数据时,一个服务器充当主服务器(master),其余的服务器充当从服务器(slave)。因为复制是异步进行的,所以从服务器不需要一直连接着主服务器,从服务器甚至可以通过拨号断断续续地连接主服务器。通过配置文件,可以指定复制所有的数据库,某个数据库,甚至是某个数据库上的某个表。

使用主从同步的好处:

(1) 通过增加从服务器来提高数据库的性能,在主服务器上执行写入和更新,在从服务器上向外提供读功能,可以动态地调整从服务器的数量,从而调整整个数据库的性能。

(2) 提高数据安全,因为数据已复制到从服务器,从服务器可以终止复制进程,所以,可以在从服务器上备份而不破坏主服务器相应数据

(3) 在主服务器上生成实时数据,而在从服务器上分析这些数据,从而提高主服务器的性能

 配置主从同步的基本步骤

有很多种配置主从同步的方法,可以总结为如下的步骤:

(1) 在主服务器上,必须开启二进制日志机制和配置一个独立的ID

(2) 在每一个从服务器上,配置一个唯一的ID,创建一个用来专门复制主服务器数据的账号

(3) 在开始复制进程前,在主服务器上记录二进制文件的位置信息

(4) 如果在开始复制之前,数据库中已经有数据,就必须先创建一个数据快照(可以使用mysqldump导出数据库,或者直接复制数据文件)

(5) 配置从服务器要连接的主服务器的IP地址和登陆授权,二进制日志文件名和位置

详细配置主从同步的方法

安装

docker image pull mysql:5.7.22

复制配置

cd
mkdir mysql_slave
cd mysql_slave
mkdir data
cp -a /etc/mysql/mysql.conf.d ./

修改配置

编辑 ~/mysql_slave/mysql.conf.d/mysqld.cnf 文件,让此台mysql运行在8306端口上,且编号为2

port  =  8306
general_log  = 0
server-id  = 2

 

运行镜像-----》创建docker容器,在容器中运行Mysql

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

# 解释:
--name : 容器名
-e MYSQL_ROOT_PASSWORD=mysql :设置root账号的密码为mysql
-d --network=host :使用主机的网络ip
-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 -pmysql -h 127.0.0.1 --port=8306

备份主服务器原有数据到从服务器

如果在设置主从同步前,主服务器上已有大量数据,可以使用mysqldump进行数据备份并还原到从服务器以实现数据的复制。

在主服务器Ubuntu上进行备份(导出数据),执行命令:

mysqldump -uroot -pmysql --all-databases --lock-all-tables > ~/master_db.sql

解释

-u :用户名

-p :示密码

--all-databases :导出所有数据库

--lock-all-tables :执行操作时锁住所有表,防止操作时有数据修改

~/master_db.sql :导出的备份数据(sql文件)位置,可自己指定

在docker容器中导入数据

mysql -uroot -pmysql -h127.0.0.1 --port=8306 < ~/master_db.sql

配置主服务器master(Ubuntu中的MySQL)

编辑设置mysqld的配置文件,设置log_bin和server-id

sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf

添加

server-id = 1 # 不和从的id一样就行

log_bin =/var/log/mysql/mysql-bin.log

重启mysql服务

sudo service mysql restart

登入主服务器Ubuntu中的mysql,创建用户slave,分配复制权限

mysql –uroot –pmysql

GRANT REPLICATION SLAVE ON *.* TO 'slave'@'%' identified by 'slave';

FLUSH PRIVILEGES;

获取主服务器的二进制日志信息

SHOW MASTER STATUS;  # 记录下File,Position的值,配置从服务器会用到

配置从服务器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服务器,并查看同步状态---》两个yes

start slave;
show slave status G

成功状态 Slave_IO_Running: Yes
Slave_SQL_Running: Yes

 

 

原文地址:https://www.cnblogs.com/xiaolu915/p/10510374.html