MySQL主从搭建

首先准备好两台centos7的服务器

1.关闭防火墙

1 systemctl stop firewalld
2 setenforce 0

2.安装MySQL客户端和服务端

yum -y install mariadb mariadb-server

3.启动MySQL服务

1 systemctl enable mariadb
2 systemctl start mariadb

4.更改配置文件,开启二进制日志

vim /etc/my.cnf
	在mysqld下增加内容:
		server-id=1
		log-bin=mysql-bin

  保存退出后重启MySQL

  systemctl restart mariadb

5.登录到本地mysql上,给从(slave)主机授权 同步日志的权限

1 grant replication slave on *.* to 'tom'@'192.168.153.%' identified by '123';
2 flush privileges;

6.查看二进制日志和位置

 

主(master)配置完毕

从(slave)主机的操作

1.关闭防火墙

1 systemctl stop firewalld
2 setenforce 0

2.安装MySQL客户端和服务端

yum -y install mariadb mariadb-server

3.启动MySQL服务

1 systemctl enable mariadb
2 systemctl start mariadb

4.更改配置文件,开启二进制日志

vim /etc/my.cnf
	在mysqld下增加内容:
		server-id=1
		log-bin=mysql-bin

  保存退出后重启MySQL

  systemctl restart mariadb

登录本地mysql上,执行同步master二进制日志操作

mysql> stop slave;			\停止slave同步
mysql> change master to
    -> master_host='192.168.153.171',    \master主机的ip地址
    -> master_user='tom',			      \登录master主机的账号
    -> master_password='123',		       \登录的密码
    -> master_log_file='mysql-bin.000003',   \二进制日志文件
    -> master_log_pos=7242321;		  \二进制日志文件的位置
mysql> start slave;		         \开启slave同步

 查询slave状态
   mysql> show slave status G;

注意以下两个线程的状态都为Yes,说明配置成功
               Slave_IO_Running: Yes
               Slave_SQL_Running: Yes

测试
在主上创建一个数据库,在从查看能够成功同步既是成功!

原文地址:https://www.cnblogs.com/xianglei_/p/12068241.html