MySQL性能优化(九)-- 主从复制
一、概念
Mysql复制(replication)是一个异步的复制,从一个Mysql 实例(Master)复制到另一个Mysql 实例(Slave)。实现整个主从复制,需要由Master服务器上的IO进程,和Slave服务器上的Sql进程和IO进程共从完成。要实现主从复制,首先必须打开Master端的binary log(bin-log)功能,因为整个 MySQL 复制过程实际上就是Slave从Master端获取相应的二进制日志,然后再在自己slave端完全顺序的执行日志中所记录的各种操作。 (二进制日志几乎记录了除select以外的所有针对数据库的sql操作语句)
二、复制解决的问题
(1) 数据分布 (Data distribution )
(2) 负载平衡(load balancing)
(3) 备份(Backups)
(4) 高可用性和容错行 High availability and failover
三、复制的原理
(1) master将改变记录到二进制日志(binary log)中(这些记录叫做二进制日志事件,binary log events);
(2) slave将master的binary log events拷贝到它的中继日志(relay log);
(3) slave重做中继日志中的事件,将更改应用到自己的数据上。
下图描述了复制的过程:
该过程的第一部分就是master记录二进制日志。在每个事务更新数据完成之前,master在二日志记录这些改变。MySQL将事务串行的写入二进制日志,即使事务中的语句都是交叉执行的。在事件写入二进制日志完成后,master通知存储引擎提交事务。
下一步就是slave将master的binary log拷贝到它自己的中继日志。首先,slave开始一个工作线程——I/O线程。I/O线程在master上打开一个普通的连接,然后开始binlog dump process。Binlog dump process从master的二进制日志中读取事件,如果已经跟上master,它会睡眠并等待master产生新的事件。I/O线程将这些事件写入中继日志。
SQL slave thread(SQL从线程)处理该过程的最后一步。SQL线程从中继日志读取事件,并重放其中的事件而更新slave的数据,使其与master中的数据一致。只要该线程与I/O线程保持一致,中继日志通常会位于OS的缓存中,所以中继日志的开销很小。
此外,在master中也有一个工作线程:和其它MySQL的连接一样,slave在master中打开一个连接也会使得master开始一个线程。复制过程有一个很重要的限制——复制在slave上是串行化的,也就是说master上的并行更新操作不能在slave上并行操作。
四、配置
1. 创建一个数据库 : create database testXbq;
2. 创建表:create table student(id int primary key auto_increment,name varchar(20));
3. 先将master上的数据复制到slave上(基于二进制日志备份(默认是关闭的))
(1)先开启二进制日志:
编辑配置文件:vi /etc/my.cnf,在里面增加
log-bin=mysql-bin // 二进制存放的目录和名字
binlog_format=mixed //
server-id=1 // 标志 master的唯一标识
(2)重启mysql: service mysql restart
(3)查看master的状态:show master status;
(4)查看目录下的二进制文件: ll /var/lib/mysql
其中,mysql-bin.index存的是:
(5)基于 位置 备份
mysqldump -uroot -p --single-transaction --master-data=2 --triggers --routines --all-databases > xbq.sql
// 基于独立的事务 // =2 注释掉 =1 不注释 // 备份到当前目录下xbq.sql
查看 xbq.sql,会发现如下(或者 直接重启master后 登录mysql,执行 show master status也可以看到 从 mysql-bin.000001的579位置开始复制):
后续的复制工作会从 mysql-bin.000001的579位置开始复制。
(6)master需要授权 一个用户给 slave,即建立一个复制账号,在master上执行(可以通过 ? grand 查看 grand的语法):
grant replication slave on *.* to 'reppc'@'%' identified by 'xbq123'; // 一般不用root帐号,% 表示所有客户端都可能连,只要帐号,密码正确,此处可用具体客户端IP代替,如192.168.1.112,加强安全。
需要刷新权限 才可以生效: flush privileges;(此时,在salve上连接 master的数据库)
(7)重启master
(8)在slave上应用 xbq.sql,有两种方式:(master中执行下面命令,ip换成slave的ip)
方法一:远程拷贝到 slaver, scp root@192.168.242.129:/usr/xbq.sql /usr/xbq.sql ,机器上需安装openssh-client,yum install -y openssh-client
方法二:远程连接 执行sql, mysql -h192.168.242.129 -uroot -p < /usr/xbq.sql,前提,需要在slave上给master远程连接的权限,如下:
grant all privileges on *.* to 'root'@'master的IP' identified by 'master的mysql密码' with grant option;
FLUSH PRIVILEGES;
4.slave 应用sql(前提:slave中已经有了master导出的sql文件,以下命令在slave中执行。如果使用 (8)中的方法二的话,忽略此步骤)
方法一: source /usr/xbq.sql
方法二: mysql -uroot -p < /usr/xbq.sql
经过上面的操作 master上的数据 就到了 slave中
5.复制的过程:
(1)slave开始二进制日志,和 master一样的配置 ,但是 server-id 需要 =2。然后重启salve上的mysql。
验证在slave上是否可以登录master,mysql -u root -h master的IP -p ,输入密码后,可以登录 则证明可以登录。否则,需要在 master上给slave授权,如下:
grant all privileges on *.* to 'root'@'slave的IP' identified by 'slave的mysql密码' with grant option;
FLUSH PRIVILEGES;
(2)让slave连接master,并开始重做master二进制日志中的事件(可以通过 ? change master to 查看语法):
change master to master_host='192.168.242.129', master_user='reppc',master_password='xbq123', master_port=3306,master_log_file='mysql-bin.000001',master_log_pos=579;
从 服务器的哪一个日志的哪一个位置 复制。
其中,master_host是master的IP,master_user是在master中赋予复制权限的用户,master_log_file是master中二进制文件,master_log_pos是开始复制的位置。
(3)查看IOThread和SQLThread是否成功,只有 这两个状态 都是 YES才可以复制。
(4)查看maste上的用户表 select * from mysql.user \G,看到多了一个 我们刚刚指定的用户,看到 此记录 的 reppc:Y ,即说明该用户 具有复制的权限
此时,master已经配置ok了,查看状态:show master status;
(5)先重启slave:
(6) 查看salve的状态 show slave status :
出现 Slave-IO-Running:YES,Slave-SQL-Running :YES ,则主从配置成功!
五.测试
(1)在matser中的 student 表中新增加一条记录:
insert into student(name) values('徐邦启');
(2)在slave中查看student表:
OK!
六、常用命令
1.查看二进制日志:
方法一:mysql> show binlog events in ‘日志文件’ from 位置;
方法二:使用mysql工具查看日志文件(二进制日志中包含中各种DML和DDL)
# mysqlbinlog --no-defaults mysql-bin.000001 查看指定文件binlog
# mysqlbinlog --start-position=位置 日志路径,例如: mysqlbinlog -start-position=120 /var/lib/mysql/mysql-bin.000001
# 查看某个时间段的二进制日志,并且输出到指定的文件
mysqlbinlog --no-defaults --start-datetime="2018-12-12 13:00:00" --stop-datetime="2018-12-12 14:40:00" mysql-bin.000085 -vv --base64-output=decode-rows | more >> target.txt # 查看某个二进制日志中的指定命令,并且输出到指定的文件
mysqlbinlog --no-defaults --base64-output=decode-rows -v -v mysql-bin.000085 | sed -n '/### DELETE FROM `数据库名`.`表名`/,/COMMIT/p' > target.txt # 将@1、@2等一系列看不懂的符号转换为SQL语句
cat target.txt | sed -n '/###/p' | sed 's/### //g;s/\/\*.*/,/g;s/DELETE FROM/INSERT INTO/g;' | sed -r 's/(@4.*),/\1;/g' | sed 's/@[0-9]*\=//g' > test.sql # 查看某个二进制日志的某个时间段内 DELETE 语句出现的次数
mysqlbinlog --no-defaults --start-datetime="2018-12-12 13:00:00" --stop-datetime="2018-12-12 14:40:00" mysql-bin.000085 -d 数据库名 mysql-bin.000085 -v|grep UPDATE | wc -l
2.查看中继日志(和查看二进制日志是同一个命令):
mysql> show relaylog events in ‘日志文件’ from 位置;
3.查看mysql线程列表:
mysql> processlist;
4.查看mysql的配置文件(my.cnf)目录:whereis my.cnf
5.查看mysql的配置文件(my.cnf)目录:mysql --verbose --help | grep -C 1 'Default opt'
6.清空master:reset master;
七、说明
本文是一主一从,当然,一主多从也是一样的道理,在增加一台slave,然后在my.cnf修改,然后 change master to,在master上 修改 change master to master_host= '192.168.242.%'。
MySQL性能优化(九)-- 主从复制的更多相关文章
- MySQL性能优化总结
一.MySQL的主要适用场景 1.Web网站系统 2.日志记录系统 3.数据仓库系统 4.嵌入式系统 二.MySQL架构图: 三.MySQL存储引擎概述 1)MyISAM存储引擎 MyISAM存储引擎 ...
- mysql 性能优化方案
网 上有不少MySQL 性能优化方案,不过,mysql的优化同sql server相比,更为麻烦与复杂,同样的设置,在不同的环境下 ,由于内存,访问量,读写频率,数据差异等等情况,可能会出现不同的结果 ...
- mysql 性能优化方案1
网 上有不少mysql 性能优化方案,不过,mysql的优化同sql server相比,更为麻烦与复杂,同样的设置,在不同的环境下 ,由于内存,访问量,读写频率,数据差异等等情况,可能会出现不同的结果 ...
- mysql 性能优化方案 (转)
网 上有不少mysql 性能优化方案,不过,mysql的优化同sql server相比,更为麻烦与复杂,同样的设置,在不同的环境下 ,由于内存,访问量,读写频率,数据差异等等情况,可能会出现不同的结果 ...
- MySQL性能优化总结(转)https://yq.aliyun.com/articles/24249
摘要: 一.MySQL的主要适用场景 1.Web网站系统 2.日志记录系统 3.数据仓库系统 4.嵌入式系统 二.MySQL架构图: 三.MySQL存储引擎概述 1)MyISAM存储引擎 MyIS ...
- MySQL 性能优化
内容简介:这是一篇关于mysql 性能,mysql性能优化,mysql 性能优化的文章.网上有不少mysql 性能优化方案,不过,mysql的优化同sql server相比,更为麻烦与负责,同样的设置 ...
- MySQL性能优化总结___本文乃《MySQL性能调优与架构设计》读书笔记!
一.MySQL的主要适用场景 1.Web网站系统 2.日志记录系统 3.数据仓库系统 4.嵌入式系统 二.MySQL架构图: 三.MySQL存储引擎概述 1)MyISAM存储引擎 MyISAM存储引擎 ...
- MySQL 性能优化技巧
原文地址:MySQL 性能优化技巧 博客地址:http://www.extlight.com 一.背景 最近公司项目添加新功能,上线后发现有些功能的列表查询时间很久.原因是新功能用到旧功能的接口,而这 ...
- MySQL性能优化总结(转)
MySQL性能优化总结 一.MySQL的主要适用场景 1.Web网站系统 2.日志记录系统 3.数据仓库系统 4.嵌入式系统 二.MySQL架构图: 三.MySQL存储引擎概述 1)MyISAM存 ...
- MySQL性能优化(七):其它优化
原文:MySQL性能优化(七):其它优化 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn.net/v ...
随机推荐
- sparkr脚本
test <- function(){ print(1) } test() 脚本内为单独函数时 调用脚本不执行 所以要在脚本内调取特定函数
- 安卓程序代写 网上程序代写[原]BluetoothClass详解
一. BluetoothClass简介 1. 继承关系 public final class BluetoothClass extends Object implements Parcelable 该 ...
- 《FPGA全程进阶---实战演练》第九章 计数器要注意
本小节我们来做一个好玩的事情,就是计数器,还记得在做LED自加实验时我们就曾经提到过关于计数器的相关议题,那么这节我们就来讨论讨论. 探讨一下如下的问题:请用verilog记八个数的写法,分析这个可以 ...
- IntelliJ IDEA 13.1.3 SVN无法正常使用问题
http://my.oschina.net/luckyi/blog/291007 最新升级IDEA12到13版本,升级后发现IDEA中SVN无法正常使用,但文件夹下能够正常使用. 并且报错:svn: ...
- mock数据和代码生成
git clone https://gitee.com/fleam/CodeGeneration.git
- 【转】【Android】Android Studio打包全攻略
项目写完了,现在需要把应用上传到市场,问题出现—怎么把代码变成.apk(Android的可安装文件).1. 创建签名文件2. 填写好签名参数3. 生成APK注意:签名的密码和密匙的密码注意保管,不要忘 ...
- GROUP BY、HAVING、AS 的用法小例子
需求: 查询选休了5门课程的学生的姓名 分析: 1. 先从 t_sc 表中查出 选了5门课的学生的学号: SELECT COUNT(code) AS countCourse,sid FROM t_sc ...
- Salt-ssh批量自动安装被控端salt-mini
Salt-ssh是Saltstack的另外一种管理方式,无需安装minion端,可以运行salt的一切功能,管理和使用方法基本和salt一样.但是,salt-ssh并没有继承原来的ZeroMQ通讯架构 ...
- Linux Shell 基本语法
一. Linux基本命令 1.1. cp命令 该命令的功能是将给出的文件或目录拷贝到另一文件或目录中,功能十分强大. 语法: cp [选项] 源文件或目录 目标文件或目录 1.2. mv命令 用户可 ...
- Java设计模式之七大结构型模式(附实例和详解)
博主在大三的时候有上过设计模式这一门课,但是当时很多都基本没有听懂,重点是也没有细听,因为觉得没什么卵用,硬是要搞那么复杂干嘛.因此设计模式建议工作半年以上的猿友阅读起来才会理解的比较深刻.当然,你没 ...