MySQL读写分离

三世轮回 提交于 2019-12-18 10:57:25

一、读写分离(主从复制)

主从复制:当主服务器有写入(insert/update/delete)语句时候,从服务器自动获取
读写分离:insert/update/delete语句操作一台服务器,select操作另一个服务器


从库生成两个线程,一个I/O线程,一个SQL线程;
i/o线程去请求主库 的binlog,并将得到的binlog日志写到relay log(中继日志) 文件中;
主库会生成一个 log dump 线程,用来给从库 i/o线程传binlog;
SQL 线程,会读取relay log文件中的日志,并解析成具体操作,来实现主从的操作一致,而最终数据一致

 

二、bin-log日志

概念:binlog即二进制日志,它记录了数据库上的所有改变并以二进制的形式保存在磁盘中,它可以用来查看数据库的变更历史、数据库增量备份和恢复、Mysql的复制(主从数据库的复制)。
简单概括:binlog日志就是记录MySQL数据库增/删/改SQL语句
作用:实现主从复制、灾难恢复

1、开启binlog日志
步骤1:打开MySQL配置文件vi /etc/my.cnf并修改


步骤2:重启服务


步骤3:登录MySQL查看bin-log日志是否开启

 


2、查看binlog日志里面的内容
列表:show master logs
清空:reset master
刷新:flush logs
查看指定日志:show binlog events in '日志键名'
步骤1:查看列表


步骤2:刷新(生成一个新文件存储)

 


步骤3:创建d1数据库和t1表
create database data1;
use data1;
create table table1 (id int);
步骤4:查看binlog日志中的SQL语句

 

三、主从复制具体配置步骤

1、配置主服务器
步骤1:修改配置文件,开启binlog日志
步骤2:修改配置文件,设置一个server_id=数字(注:数字必须唯一)


步骤3:重启服务
步骤4:创建用户(目的,让从服务器来复制数据)
create user 'copyer'@'%' IDENTIFIED BY '666666';
grant all on . to 'copyer'@'%';
FLUSH PRIVILEGES;
步骤5:关闭防火墙或开放3306端口
2、配置从服务器
步骤1:修改配置文件,设置一个server-id=数字(注:数字必须唯一)


步骤2:重启服务
步骤3:通过change master 语句指定同步主位置
-> 切换到主服务器并查看当前主服务器信息,通过SQL语句:【show master status】


-> 切换到从服务器执行同步语句
change master to
master_host='192.168.142.131',master_user='copyer',master_password="666666",master_log_file='localhost-bin.000013',master_log_pos=839;


步骤4:从服务器开启同步


步骤5:从服务器验证


注意:
-> 如果出现错误,可以重新登陆MySQL然后重启slave服务尝试。
-> 如果使用的是虚拟机克隆的两个系统,则MySQL是一样的,也会报错’UUIDs’问题,需要删除MySQL数据目录下的auto.cnf然后重启(注:重启后会自动创建一个唯一的uuid),然后重启nysql服务即可。
3、测试

 

--------------------------------------------------------------------------------分割线--------------------------------------------------------------------------------

 

1.  环境

操作系统:CentOS-7

MySQL:mysql-5.6

一台虚拟机又克隆了两台

192.168.102.31  master

192.168.102.56  slave

192.168.102.36  slave

启动/停止

service  mysqld  start|stop|restart
systemctl  start|stop|restart  mysqld

本机的话,直接mysql就可以进去了

2.  主数据库配置

第1步:编辑/etc/my.cnf文件,在[mysqld]下增加如下两行设置:

[mysqld]
log-bin=mysql-bin # 非必需
server-id=1    # 必需

第2步:创建用于数据同步的账户

CREATE USER 'repl'@'192.168.102.%' IDENTIFIED BY '123456';
GRANT REPLICATION SLAVE ON *.* TO 'repl'@'192.168.102.%';
FLUSH PRIVILEGES;

第3步:查看master状态

show master status;

3.  从数据库配置

第1步:编辑/etc/my.cnf文件,设置server-id

[mysqld]
server-id=2

第2步:执行同步语句,并启动slave

change master to master_host='192.168.102.31', master_user='repl', master_password='123456', master_log_file='mysql-bin.000001', master_log_pos=514;

第3步:查看slave状态

show slave status\G;

另外一台从数据库也是这样设置

4.  验证是否同步成功

在主数据上操作,从数据库中查看

5.  设置只读账户

mysql> create user 'pig'@'%' identified by '123456';
mysql> grant select on test.* to 'pig'@'%';
mysql> flush privileges;

 

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!