1 mysql主从同步

1.1主数据库配置:

环境:准备两台机器,一台作为主数据库,一台作为从数据库

(1)用户授权

mysql> grant  replication  slave on *.*  to  用户名@"从服务器地址"

identified by "密码";

(2)启用binlog日志

vim  /etc/my.cnf

server_id=54

log-bin=master54

binlog-format="mixed"

(3)重启数据库服务器

systemctl restart mysqld

ls /var/lib/mysql/master54.*

/var/lib/mysql/master54.000001  /var/lib/mysql/master54.index

(4)查看正在使用binlog日志文件。

# mysql -uroot -p123456

mysql> show  master  status;

1.2 从服务器配置

(1)显示自己是否是从数据库服务器

mysql> show slave status;

(2)测试主库授权的用户是否有效

#mysql  -h192.168.4.54  -uyaya  -p123456

mysql> show grants;

(3)修改配置文件指定server_id

#vim /etc/my.cnf

[mysqld]

server_id=55

#sync-binlog=1 #允许日志同步

#read_only=1  #只读模式

重启:systemctl  restart  mysqld

(4)在本机数据管理员登录主库信息

mysql> change master  to

    -> master_host="192.168.4.54",

    -> master_user="yaya",

    -> master_password="123456",

    -> master_log_file="master54.000001",

-> master_log_pos=数字; #查看主的Position(偏移位置)

(5)开启从服务

mysql> start slave;

mysql> show slave status\G;

            Slave_IO_Running: Yes

            Slave_SQL_Running: Yes

必须保证Slave_IO,Slave_SQL的状态为yes。如果不是,查看如下配置文件:

[root@ser55 ~]# vim /var/lib/mysql/auto.cnf

(6)验证主从同步配置:结果

客户端连接主库服务器 产生的新数据,在从角色的主机上都能够查看到。

1.3 工作原理

从角色主机的数据库目录下会多出如下文件:

master.info  #存储主数据库的信息

slave55-relay-bin.XXXXXX   

#中继日志文件(二进制文件,使用mysqlbinlog查看)

slave55-relay-bin.index #中继文件索引

relay-log.info   #记录当前数据库服务器使用的中继日志文件

IO线程的作用:把主库的binlog日志内容记录到本机的relay-log日志里

SQL线程的作用:执行本机中继(relay-log)日志的sql命令,把数据写到本机的库。

mysql > show processlist;

Binlog Dump 把binlog的日志通过IO线程发给从库,从库通过SQL命令执行日志的语句,达到与主的数据库一致。

1.4 主从排错

IO线程报错:从库指定主库的信息错误

安全限制(selinux,firewall)

查看Last_IO_Error的报错信息

哪一项错误就改哪一项,change master to

SQL线程报错:

执行中继日志里的sql命令时,从库的库或者表不存在

查看报错信息:

Last_SQL_Error: 报错信息

mysql> stop  slave;  (reset slave)

在从本机有命令操作的库或表

mysql> start  slave;

1.5 让从数据库临时不同步主库的数据

mysql> stop slave;

把从库还原成独立的数据库

rm -rf master.info  relay-bin.*  relay-log.info

1.6 主从同步常用配置参数:

主数据服务器使用的参数

[mysqld]

binlog_do_db=db1,db2      #只允许Master对哪些库记日志

binlog_ignore_db=db1,db2   #只不允许Master对哪些库记日志

从数据服务器使用的参数

[mysqld]

log_slave_updates      允许级联复制(主从从)

replicate_do_db=db1,db2(数据库库名)  只同步库1和库2

replicate_ignore_db=db1,db2            只不同步库1和库2

relay_log=名 指定中继日志文件名

2 读写分离

2.1 配置读写分离

2.11 环境:基于主从

一台机器作为主数据库,一台为从数据库,一台为Mysql代理

2.12 为什么要做读写分离:

减轻服务器的并发访问压力同时提高硬件利用率。

2.13 配置maxscale

在mysql代理上配置

(1)装包

[root@ser53 ~]# rpm -ivh maxscale-2.1.2-1.rhel.7.x86_64.rpm

[root@ser53 ~]# rpm -qc  maxscale

/etc/maxscale.cnf.template

(2)配置文件说明

vim /etc/maxscale.cnf

[maxscale]      #服务名称

threads=1      #(=auto自动的)线程数,默认为1,不改动

[server1]        #调用服务器的名称,指定ip地址对应的名字

type=server

address=192.168.4.54  #主数据库服务器ip地址

port=3306              #端口

protocol=MySQLBackend

[server2]

type=server

address=192.168.4.55

port=3306

protocol=MySQLBackend

 

[MySQL Monitor]      #指定要监控的主机 和监控时连接的用户

type=monitor

module=mysqlmon

servers=server1,server2

user=scalemon       #监控数据库服务服务的运行状态和主从状态的用户

passwd=123456

monitor_interval=10000

 

#[Read-Only Service]  #只读服务,不需要使用,注释掉

#type=service

#router=readconnroute

#servers=server1

#user=myuser

#passwd=mypwd

#router_options=slave

 

[Read-Write Service]      #定义读写分离服务器列表

type=service

router=readwritesplit

servers=server1,server2    #前边定义的主机名

user=maxscale    

#检查接收客户端连接请求时,连接的用户名和密码在数据库服务器上是否存在

passwd=123456           #密码

max_slave_connections=100%

 

[MaxAdmin Service]

type=service

router=cli

 

#[Read-Only Listener]

#type=listener

#service=Read-Only Service

#protocol=MySQLClient

#port=4008

 

[Read-Write Listener]

type=listener

service=Read-Write Service

protocol=MySQLClient

port=4006

[MaxAdmin Listener]

type=listener

service=MaxAdmin Service

protocol=maxscaled

socket=default

port=4010   #admin的监听端口

2.14 根据配置文件的设置在数据库服务器添加对应的授权用户。

(只在主服务器授权即可 从服务器会自动同步)

mysql> grant replication slave, replication client on *.*

to scalemon@'%'  identified by “123456”;  #创建监控用户

mysql> grant select on mysql.* to maxscale@'%' identified

by “123456”;  #创建路由用户

mysql> grant all  on *.*  to  student@'%' identified by “123456”;

#创建客户端访问用户

2.15 启动maxscale服务

maxscale --config=/etc/maxscale.cnf

或者maxscale -f /etc/maxscale.cnf

netstat -utnalp | grep maxscale

kill -9 pid号       #通过杀进程的方式停止服务

[root@ser53 ~]# ps -C maxscale

2.16 测试

[root@ser52 ~]# mysql -ustudent -p123456  -h192.168.4.53 -P4006

写入一条数据,此时在主数据库上能查看到,在从服务器上也能查到,说明在主服务器上进行写操作。

[root@ser53 ~]# maxadmin -P4010 -uadmin -pmariadb #进入管理

MaxScale> list servers   #查看服务器列表状态

可以在从服务器上数据库内写数据,而此时主数据库并没有从库写入数据的信息,从其它客户端访问mysql代理,去查看数据库内的内容,如果能查到写的数据,就能确定在从库上查看。