Mysql主从架构的复制
复制类型
(1)基于语句的复制: 在主服务器上执行的SQL语句,在从服务器上执行同样的语句。MySQL默认采用基于语句的复制,效率比较高。 一旦发现没法精确复制时,会自动选着基于行的复制。
(2)基于行的复制:把改变的内容复制过去
(3)混合类型的复制: 默认采用基于语句的复制,一旦发现基于语句的无法精确的复制时,就会采用基于行的复制。
复制解决的问题
(1) 数据分布
(2) 负载平衡
(3) 备份
(4) 高可用性和容错行
步骤
(1) master将改变记录到二进制日志中(binary log);
(2) slave将master的binary log拷贝到它的中继日志(relay log);
(3) slave重做中继日志中的事件,将改变反映它自己的数据。
配置
主服务器必须激活二进制日志功能。从服务器必须具备让它连接主服务器并请求主服务器把二进制变更日志传输给它的权限
关停Master服务器,将Master中的数据拷贝到B服务器中,使得Master和slave中的数据同步,并且确保在全部设置操作结束前,
禁止在Master和slave服务器中进行写操作,使得两数据库中的数据一定要相同
1.在Master的数据库中建立一个备份帐户:每个slave使用标准的MySQL用户名和密码连接maste
授予REPLICATION SLAVE权限
create user backup; GRANT REPLICATION SLAVE ON *.* TO 'backup'@'10.0.0.1' IDENTIFIED BY '123456';
2.设置master
my.ini文件,在[mysqld]下面增加
log-bin=mysql-bin server-id=1 innodb_flush_log_at_trx_commit=1 sync_binlog=1 binlog-do-db=mshop binlog_ignore_db=mysql
注:
server-id=1中的1可以任定义,只要唯一的就行。
binlog-do-db=wordpress是表示只备份wordpress。
binlog_ignore_db=mysql表示忽略备份mysql。不加binlog-do-db和binlog_ignore_db,表示备份全部数据库
重启mysql,是否成功,用show variables like "%log_%";
SHOW MASTER STATUS可查看日志
3.设置slave
my.ini文件,在[mysqld]下面增加
log_bin = mysql-bin server_id = 2 relay_log = mysql-relay-bin log_slave_updates = 1 read_only = 1
slave没有必要开启二进制日志,但是如果slave为其它slave的master,必须设置bin_log
4.启动slave
让slave连接master,并开始重做master二进制日志中的事件
change master to master_host='10.0.0.1', //Master 服务器Ip master_port=3306, master_user='backup', master_password='123456', master_log_file='mysql-bin.000001',//Master服务器产生的日志 master_log_pos=0;
5.启动slave
start slave;
6.检查是否正常
(1)在主服务器上执行
SHOW MASTER STATUS
(2)在从服务器上执行
SHOWSHOW SLAVE STATUS
检查是否slave_IO_Running和slave_SQL_Running的值均为Yes
Slave_IO_Running 如果是 Yes 的话代表成功从主服务器中同步到 bin-log 日志
Slave_SQL_Running 如果是 Yes 的话代表成功执行 bin-log 日志中的 SQL 语句
(3)如果从服务器正在运行,查看是否建立了与主服务器的连接
SHOW PROCESSLIST
如果I/O线程状态为Connecting to master,验证主服务器上复制用户的权限、主服务器主机名、DNS设置,是否主服务器真正在运行,以及是否可以从从属服务器访问
注意:主服务器与从服务器的时区必须一致,否则mysql执行与时间相关的函数将会导致数据不一致
7.复制的基本原则
(1) 每个slave只能有一个master;
(2) 每个slave只能有一个唯一的服务器ID;
(3) 每个master可以有很多slave;
(4) 如果你设置log_slave_updates,slave可以是其它slave的master,从而扩散master的更新
说明:编写一shell脚本,用nagios监控slave的两个yes。如果都是yes,就表明主从有问题了。Nagios是一个监视系统运行状态和网络信息的监视系统。可运行在Linux/Unix平台之上,同时提供一个可选的基于浏览器的WEB界面以方便系统管理人员查看网络状态,各种系统问题,以及日志等