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