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界面以方便系统管理人员查看网络状态,各种系统问题,以及日志等
最新文章
- 在公有云AZURE上部署私有云AZUREPACK以及WEBSITE CLOUD(二)
- sublime text 3 使用方法
- iOS-网络爬虫
- 关于Mysql错误:./bin/mysqld_safe --user=mysql&; [1] 32710 121003 16:40:22 mysqld_safe Logging to '/var/log/mysqld.log'. 121003 16:40:22 mysqld_s
- mysql自动化安装
- 利用Oracle的row_number() over函数消除重复的记录
- JAVA编程思想第一题出现错误
- MapReduce数据流向分析
- (整理)ubuntu 的 相关知识(来自 鸟哥的私房菜)
- 求职(2015南京站获得百度、美的集团、趋势科技、华为offer)
- leetcode Maximum Depth of Binary Tree python
- 解决VTune错误.../lib64/libstdc++.so.6: version `GLIBCXX_3.4.14&;#39; not found (required by ...)
- Hadoop datanode 磁盘自动化处理
- HTML <;area>;<;map>;标签及在实际开发中的应用
- uva437 DAG
- CSS3动画属性:变形(transform)
- 转载 --mysql函数大全
- java.io.IOException: Server returned HTTP response code: 411 for URL
- mac OS X下Java项目环境搭建+IntelliJ IDEA Jrebel插件安装与破解+Office 2016破解版安装
- Shiro中Realm
热门文章
- java文档注释--javadoc的用法
- html5上传图片(一)一跨域上传
- iOS 字典或者数组和JSON串的转换
- app字体被放大效果发虚
- android Activity介绍
- 3D坦克大战游戏源码
- DX12龙书第6章习题
- 模块化之Spring3.0 web fragment和gradle构建项目
- backup log is terminating abnormally because for write on file failed: 112(error not found)
- JAVA编程思想(第四版)学习笔记----4.8 switch(知识点已更新)