MySQL支持单向、异步复制,复制过程中一个服务器充当主服务器,而一个或多个其它服务器充当从服务器。主服务器将更新写入二进制日志文件,并维 护日志文件的一个索引以跟踪日志循环。当一个从服务器连接到主服务器时,它通知主服务器从服务器在日志中读取的最后一次成功更新的位置。从服务器接收从那 时起发生的任何更新,然后封锁并等待主服务器通知下一次更新。
为什么使用主从复制?
1、主服务器/从服务器设置增加了健壮性。主服务器出现问题时,你可以切换到从服务器作为备份。
2、通过在主服务器和从服务器之间切分处理客户查询的负荷,可以得到更好的客户响应时间。但是不要同时在主从服务器上进行更新,这样可能引起冲突。
3、使用复制的另一个好处是可以使用一个从服务器执行备份,而不会干扰主服务器。在备份过程中主服务器可以继续处理更新。
MySQL 使用3个线程来执行复制功能(其中1个在主服务器上,另两个在从服务器上。当发出START SLAVE时,从服务器创建一个I/O线程,以连接主服务器并让主服务器发送二进制日志。主服务器创建一个线程将二进制日志中的内容发送到从服务器。从服 务器I/O线程读取主服务器Binlog Dump线程发送的内容并将该数据拷贝到从服务器数据目录中的本地文件中,即中继日志。第3个线程是SQL线程,从服务器使用此线程读取中继日志并执行日志中包含的更新。SHOW PROCESSLIST语句可以查询在主服务器上和从服务器上发生的关于复制的信息。
默认中继日志使用 host_name-relay-bin.nnnnnn形式的文件名,其中host_name是从服务器主机名,nnnnnn是序 列号。用连续序列号来创建连续中继日志文件,从000001开始。从服务器跟踪中继日志索引文件来识别目前正使用的中继日志。默认中继日志索引文件名为 host_name-relay-bin.index。在默认情况,这些文件在从服务器的数据目录中被创建。中继日志与二进制日志的格式相同,并且可以用 mysqlbinlog读取。当SQL线程执行完中继日志中的所有事件后,中继日志将会被自动删除。
从服务器在数据目录中另外创建两个状态文件--master.info和relay-log.info。状态文件保存在硬盘上,从服务器关闭时不会丢失。下次从服务器启动时,读取这些文件以确定它已经从主服务器读取了多少二进制日志,以及处理自己的中继日志的程度。
1.配置主服务器
打开mysql的配置
vim/usr/local/webserver/mysql/my.cnf
开启server_id和bin-log日志
server_id = '唯一值'(开启server_id)
log-bin = /data/mysql/3306/binlog/binlog
2. 配置从服务器
打开mysql的配置
vim /usr/local/webserver/mysql/my.cnf
开启server_id和bin-log日志
server_id = '唯一值'(开启server_id)
log-bin = /data/mysql/3306/binlog/binlog
修改完配置后记得重启数据库 service mysqld restart
关键点:从数据库中必须有一个用户可以在从数据库的机器上去连接主服务器
3.在主数据库中给从数据库一个用户
进入mysql /usr/local/webserver/mysql/bin/mysql -p 密码
mysql> grant all on *.* to 用户@从数据库的ip identified by '密码';
flush privileges;刷新权限
在主数据库中查看 show master status;主数据库的最新的bin-log日志文件名
4.进入从数据库,执行下边的sql语句
检查从数据库是否可以进入
mysql /usr/local/webserver/mysql/bin/mysql -u
主数据库给的用户 -p 密码 -h主数据库的ip ,如果可以进入,则退出
mysql /usr/local/webserver/mysql/bin/mysql -u
密码
特别,在执行change之前必须关闭从库 stop slave;
mysql> change master to master_host='主数据库ip',master_user='主数据库授权的用户名',master_password='主数据库授权的密码',master_log_file='主数据库的bin-log日志的文件名',master_log_pos='主数据库的bin-log日志的position值'
5.开启从库 start slave;
6.查看从库状态 show slave status\G;
change master to master_host='101.200.136.226',master_user='zt',master_password='zt',master_log_file=' binlog.000001 ',master_log_pos=4826;
如果
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
OK没问题
主从配置完毕
binlog命令
/usr/local/webserver/mysql/bin/mysqlbinlog binlog.000001
查看binlog日志文件
reset master 初始化binlog日志
show master status; 查看最新的日志文件和position值
flush logs 刷新log日志文件
start slave 开启从库
stop slave 停止从库
show slave status;查看从库状态
通过binlog日志恢复数据
进入binlog目录
cd /data/mysql/3306/binlog/
查看binlog列表 ls
查看binlog日志文件
/usr/local/webserver/mysql/bin/mysqlbinlog binlog.000001
恢复数据
/usr/local/webserver/mysql/bin/mysqlbinlog binlog.000001 | /usr/local/webserver/mysql/bin/mysql -p(在没有清空binlog日志之前可以恢复)
如果执行了 reset master 就无法恢复
百万美食网还为您提供以下相关内容希望对您有帮助:
MySQL主从复制在不停服下实现的方法mysql不停服主从
1.使用GTID复制方式 GTID(Global Transaction ID)是MySQL 5.6版本以后新加的复制策略,它可以将所有事务操作都记录在二进制日志中,并且为每个事务分配一个独一无二的全局唯一标识,这样就可以避免在主从复制过程中出现数据不一致的问题。在使用GTID复制方式时,我们可以先关闭从库的复制服务,然后进行数据同步
看完这篇还不懂 MySQL 主从复制,可以回家躺平了
半同步复制:在异步复制的基础上,确保主库上的事务在提交之前至少有一个从库已经收到该事务并日志记录下来。这种方式提高了数据的安全性,但也会造成一定程度的延迟。延迟复制:在异步复制的基础上,人为设定主库和从库的数据同步延迟时间。六、方式 MySQL主从复制支持两种不同的日志格式,这两种日志格式...
mysql数据库主从配置
一、配置前的准备 硬件准备:确保有两台或多台服务器用于安装MySQL数据库,以实现主从同步。IP地址规划:为每台服务器分配一个唯一的IP地址,例如主服务器IP为192.168.3.100,从服务器IP为192.168.3.101。二、主服务器配置 创建复制用户:使用mysql -h 192.168.3.100 -u 数据库名称 -p登录到...
mysql 自动同步数据到另外一台服务器上
一、主从复制(Master-Slave Replication)主从复制是MySQL最常用的同步方式。主服务器记录所有写操作的二进制日志(binlog),从服务器通过I/O线程读取主节点的binlog并应用至本地数据库。优势包括高可用性、读写分离优化性能及数据备份能力。配置时需:在主节点启用二进制日志(log_bin=ON),并设置唯一...
MySQL 数据库事务与复制
从库通过I/O线程从主库拉取binlog,再由SQL线程解析并重放日志中的事件,最终将数据写入从库。主从复制流程:主库记录binlog:主库执行事务时,除更新数据外,还会将变更事件写入binlog(由MySQL Server层生成,与存储引擎无关);从库拉取binlog:从库的I/O线程通过协议连接主库,请求获取binlog并...
mysql读写分离实现方式是什么
MySQL读写分离的核心实现方式是通过中间件(如mysql-proxy、Mycat、Amoeba等)将读写请求分发至主从数据库集群,其中主库处理写操作,从库处理读操作,数据一致性通过主从复制技术保障。 以下以mysql-proxy为例详细说明实现步骤:1. 主从复制配置(基础条件)读写分离依赖主从复制实现数据同步。需先在主库...
如何配置MySQL数据库主从复制
shell> cd /usr/local/mysql/ shell> tar -cvf /tmp/mysql-snapshot.tar ./data 如果从服务器的用户账户与主服务器的不同,你可能不想复制mysql数据库。在这种情况下,应从归档中排除该数据库。你也不需要在归档中包括任何日志文件或者master.info或relay-log.info文件。当FLUSH TABLES WITH READ ...
MySQL实现主从复制不需停机mysql不停机做主从
现在,从服务器已经配置好了,我们可以开始使用它来复制主服务器的数据了。mysql> START SLAVE;现在,从服务器将从主服务器的二进制日志文件中读取更改,并确保数据库的状态与主服务器相同。完成此过程后,我们可以查看从服务器状态:mysql> SHOW SLAVE STATUS\G 在这个输出中,我们可以查看到复制进度、...
如何添加新数据库到mysql主从复制列表
首先,我们大概罗列一下主从复制的基本步骤,(MySQL主从首先需要在各自服务器配置好)。1. 复制数据库。mysqldump --master-data --single-transaction -R --databases [db_name] | gzip -9 - | pv > all-db-with-master-data.sql.gz 注意:innodb用 –single-transaction, myisam需要用 –lock...
master/slave设置方法详解
MySQL数据库中Master/Slave设置方法主要包括主服务器(Master)配置和从服务器(Slave)配置。主服务器(Master)配置步骤:编辑配置文件:需要编辑MySQL的配置文件(如my.cnf),设置服务器唯一ID(server-id),并开启二进制日志(log-bin)。二进制日志用于记录数据库的更改操作,这是主从复制的基础。创建...
Copyright © 2019- bwgh.cn 版权所有
违法及侵权请联系:TEL:199 18 7713 E-MAIL:2724546146@qq.com
本站由北京市万商天勤律师事务所王兴未律师提供法律服务