主从复制:主MySQL上的数据,新增、修改库、表、表里的数据都会同步到从MySQL服务器上
流程图:
MySQL的主从复制的模式:
异步:只要执行完之后。客户端提交事务,主MySQL会立即把结果返回给从服务器,主MySQL并不关心MySQL从MySQL是否已经接收,并且处理。主MySQL一旦崩溃,主MySQL的事务可能没有传到从MySQL,这个时候强行把从提升为主,可能到新的主MySQL,数据不完整。(很少见,工作中都是异步复制)
mysql主从复制注意点:
若主从版本不一致,从的版本一定要高于主,保证可以向下兼容
因为若主的版本更新,低版本的从无法兼容的。
主从复制和读写分离实验:
架构:
3台MySQL:
MySQL31(主)、32(从)、33(从)
test21(读写分离客户服务器)、test22(客户端)
全部关闭防火墙安全机制
三台MySQL主从服务器之间时间同步:
yum -y install ntp
vim /etc/ntp.cnf
尾行添加:
server 127.127.0.0
fudge 127.127.0.0 stratum 8
这里的IP地址第三位写的是是本机ip第三位。本机20.0.0.0,所以这里填0
stratum 数字:数字越小时间精确度越高,设置fudge 8时间层级8最高到15,从本地获取之间同步源
重启ntpd
两台从MySQL配置ntp
/usr/sbin/ntpdata 20.0.0.31 指向主MySQL
在生产中设置定时任务:crontab -e -u root
date查看时间
时间同步之后开始配置:
主MySQL:
vim /etc/my.cnf
log-bin=master-bin
binlog_format = MIXED
log-slave-updates=true ——允许从服务器复制数据时,可以从主的二进制日志写到自己的二进制日志中
重启MySQL
进入MySQL
给从服务器新建用户和授权:
grant replication slave on *.* to 'myslave'@'20.0.0.%' identified by '123456';
flush privileges;
show master status;
靠位置点同步
从MySQL:
vim /etc/my.cnf
server-id不能一样,不能重复
添加:
relay-log=relay-log-bin
relay-log-index=slave-relay-bin.index
relay_log_recovery=1 ——不加默认是0,设1表示开启中继日志的恢复。从服务器出现异常,或者崩溃时,从服务器会从主服务器的二进制日志的正确读取和应用中继日志。同步。
relay-log=relay-log-bin:
指定了从服务器上中继日志的基本文件名。在这个例子中,
中继日志的文件名将以 "relay-log-bin" 开头。
relay-log-index=slave-relay-bin.index:
指定了中继日志索引文件的名称。中继日志索引文件用于记录中继日志文件的顺序和位置。
在这个例子中,索引文件名为 "slave-relay-bin.index"。
relay_log_recovery=1:
用于配置从服务器在启动时是否执行中继日志的恢复操作。设置为 1 表示启用中继日志的恢复,
通常在从服务器出现异常或崩溃后重启时使用。
这有助于确保从服务器能够从主服务器的二进制日志中正确地读取和应用中继日志,以保持数据一致性
重启MySQL
另一台从MySQL一样配置
show master status;
根据住的二进制文件名和位置点对两个从MySQL进行同步:
主:
两个从MySQL同步:
CHANGE master to master_host='20.0.0.31',master_user='myslave',master_password='123456',master_log_file='master-bin.000001',master_log_pos=599;
配置同步,注意 master_log_file 和 master_log_pos 的值要与Master查询的一致
start slave; #启动同步,如有报错执行 reset slave;
查看slave状态:
show slave status\G;
slave_IO_Running:Yes :负责和主库的IO通信
Slave_SQL_Running:Yes :负责自己的Slave MySQL进程
若slave_IO_Running:No怎么解决?
3、
CHANGE master to master_host='192.168.233.21',master_user='myslave',master_password='123456',master_log_file='master-bin.000001',master_log_pos=604;
要么文件名写错了,要么位置偏移量不对
4、防火墙和安全机制问题(面试问,不能说这个)
到此主从复制结束
打开navicat验证:
主MySQL新建查询:
创建一个新库、新表,看从有没有同步
注意点:
主从复制是单向的,只能从主复制到从服务器
主从复制延迟问题(面试题):
解决方案:
若追求安全性配置:
innodb_flush_log_at_trx_commit=1
#每次事务提交时都会刷新事务日志。以确保持久性,最高级别的数据安全性,但是会影响性能,默认就是1
0就是事务提交时不会立刻刷新,而是每秒刷新一次,可以提高性能,但是发生故障会导致数据丢失。
2表示事务提交时,事务日志不会写入硬盘而是保存在系统缓存,同时也不会进行刷新。有一定的安全性和性能。但是对内存要求比较高。生成中一般都是默认1
sync binlog=1
#1也是默认值,每次提交事务之后,直接把二进制日志刷新到磁盘,以确保日志的持久性,占用性能比较高,但是安全性高
0表示二进制日志写入到缓存,也不会刷新日志,故障发生也会丢失数据,对内存的要求也提高了
自定义数字N:表示每N个事务才执行一次刷新到磁盘。提高性能,但是一旦崩溃数据也会大量丢失。
追求性能化配置:
sync binlog=0
innodb_flush_log_at_trx_commit=2
logs-slave-updates=0
#从库的更新不会写入二进制日志(不建议)
innodb buffer_pool_size 300M 500G
#控制innodb存储引擎缓冲池的大小,设置的数值越高,可以提高他的innodb的性能,更多的数据和索引都可以缓存在内存中。减少磁盘的访问次数。对系统内存要求比较高。
主从复制的工作过程:
主从复制问题:
要实现读写分离,第一步必须先实现读写分离
读写分离:所有的写入操作都在主库,从库只负责读(select)。如果有更新,是从主库复制到从库
为什么要有读写分离?
读写分离之后,数据库的写入和读取是分开的,哪怕写入的数据量比较大,但是不影响查询的效率。
什么场景下需要读写分离:
数据库不是一定需要读写分离的。只有在某些程序在使用数据库,更新少,但是查询较多,这种情况可以考虑读写分离
若读和差的需求差不多,也可以考虑读写分离
生产库一般都会做读写分离,测试库一般不管
在工作中,数据库的读写不可能在同一个库中完成。既不安全,也不能满足高可用,也不能实现高并发。工作中都会做读写分离
MySQL读写分离的原理:
特点:性能好,在代码中就可以实现,不需要额外的硬件设备
缺点:开发实现的,根我们无关。如果说大型的复杂的应用,设计改动的代码非常多
用Amoeba来实现读写分离:
3台MySQL:
MySQL31(主)、32(从)、33(从)
test1(读写分离客户服务器,部署Amoeba)、test2(客户端)
安装Amoeba软件和jdk环境
vim /etc/profile最后一行
export JAVA_HOME=/usr/local/jdk1.6
export CLASSPATH=.:$JAVA_HOME/lib:$JAVA_HOME/jre/lib
export PATH=$JAVA_HOME/lib:$JAVA_HOME/jre/bin/:$PATH:$HOME/bin
export AMOEBA HOME=/usr/local/amoeba
export PATH=$PATH:$AMOEBA_HOME/bin
安装Amoeba
先mkdir /usr/local/amoeba
三台MySQL设置权限,允许Amoeba可以访问
grant all on *.* to 'amoeba'@'20.0.0.%' identified by '123456';
flush privileges;
回到Amoeba客户端修改配置文件:
修改amoeba.xml 用户信息配置文件
先备份:
cp amoeba.xml amoeba.xml.bak
改配置文件:vim amoeba.xml
30行用户改成amoeba
31行修改密码123456
115行修改
修改完毕之后保存退出
修改dbservers.xml 数据库信息文件
先备份:
cp dbServers.xml dbServers.xml.bak
23行,更改注释范围
26行修改:
45行修改:
52行修改:
65行修改:
71行修改:
修改完成后
启动Amoeba+后台运行
查看java启没启动
netstat -antp | grep java
测试读写分离:
客户端安装MySQL测试:(epel源)
yum -y install epel-release
yum -y install mariadb-server mariadb
安装好了之后重启mariadb,查看端口是否启动
在所有三台主从MySQL上配置文件上加入:
开启日志:
vim /etc/my.cnf
general_log=ON
general_log_file=/usr/local/mysql/data/mysql_general.log
重启MySQL
打开三台MySQL的日志
从客户端连接Amoeba服务器进行测试:
往表中插入数据,看日志,主服务器上有写入日志记录,从服务器上有复制日志记录——写
查看表,从服务器日志有记录,主记录没有——读
实验:
mycat实现读写分离,先主从复制
实现完全同步(从库的更新也能同步到主)需要工具实现
(1)Master节点将数据的改变记录成二进制日志(bin log),当Master上的数据发生改变时,
则将其改变写入二进制日志中。
(2)Slave节点会在一定时间间隔内对Master的二进制日志进行探测其是否发生改变,如果发生改变,
则开始一个I/O线程请求 Master的二进制事件。
(3)同时Master节点为每个I/O线程启动一个dump线程,用于向其发送二进制事件,
并保存至Slave节点本地的中继日志(Relay log)中,Slave节点将启动SQL线程从中继日志中读取二进制日志,
在本地重放,即解析成 sql 语句逐一执行,使得其数据和 Master节点的保持一致,最后I/O线程和SQL线程将进入睡眠状态,
等待下一次被唤醒。
show slave status\G;
看是否有两个yes
在主库创建一个库或者表看是否能同步到从库
85%配置文件错误
1、网络问题
2、vim /etc/my.cnf配置文件错了
3、同步命令
CHANGE master to master_host='192.168.233.21',master_user='myslave',master_password='123456',master_log_file='master-bin.000001',master_log_pos=604;
要么文件名写错了,要么位置偏移量不对
4、防火墙和安全机制问题
5、show slave status\G;能看到的信息有哪些呢?
6、主从复制延迟怎么解决?
追求安全和性能
主从复制延迟问题:
1、网络延迟
2、主从硬件设备(CPU主频、内存的读写性能IO、硬件IO)
3、同步复制而不是异步复制
解决方案:
4、硬件方面:主库一般来说不需要动的太多,从库的硬件配置要更好。提升随机写的性能。硬盘可以考虑缓存固态的、升级CPU的核数、扩展一下内存。尽量使用物理机(不要用云服务器)
若追求安全性配置:
innodb_flush_log_at_trx_commit=1
#每次事务提交时都会刷新事务日志。以确保持久性,最高级别的数据安全性,但是会影响性能,默认就是1
0就是事务提交时不会立刻刷新,而是每秒刷新一次,可以提高性能,但是发生故障会导致数据丢失。
2表示事务提交时,事务日志不会写入硬盘而是保存在系统缓存,同时也不会进行刷新。有一定的安全性和性能。但是对内存要求比较高。生成中一般都是默认1
sync binlog=1
#1也是默认值,每次提交事务之后,直接把二进制日志刷新到磁盘,以确保日志的持久性,占用性能比较高,但是安全性高
0表示二进制日志写入到缓存,也不会刷新日志,故障发生也会丢失数据,对内存的要求也提高了
自定义数字N:表示每N个事务才执行一次刷新到磁盘。提高性能,但是一旦崩溃数据也会大量丢失。
追求性能化配置:
sync binlog=0
innodb_flush_log_at_trx_commit=2
logs-slave-updates=0
#从库的更新不会写入二进制日志(不建议)
innodb buffer_pool_size 300M 500G
#控制innodb存储引擎缓冲池的大小,设置的数值越高,可以提高他的innodb的性能,更多的数据和索引都可以缓存在内存中。减少磁盘的访问次数。对系统内存要求比较高。