centos7下配置mysql5.7.24主从复制
前置条件
准备两台服务器(可以是虚拟机),系统为centos7
此处演示的两台服务器:192.168.8.134、192.168.8.135
第一步:安装mysql5.7.24
先在两台服务器上安装mysql5.7.24,安装可参考:
安装成功后,启动mysql。如果是虚拟机的话,在一台安装好之后,可以使用克隆功能,克隆后的虚拟机也会有安装好的mysql。
第二步:配置主从复制
配置之前,先在两台服务器上开启mysql。
master:192.168.8.134
slave: 192.168.8.135
配置master
创建一个名为repl的用户
CREATE USER repl IDENTIFIED BY 'L2019Mysql@';
授权slave数据库REPLICATION 权限
GRANT REPLICATION SLAVE ON *.* TO 'repl'@'%' IDENTIFIED BY 'L2019Mysql@';
授权slave服务器可以通过repl用户可以远程访问master,来读取binlog中数据,实现数据同步。
修改my.cnf配置文件
sudo vim /etc/my.cnf
在/etc/my.cnf的[mysqld]下加入如下配置:
# 启用二进制日志文件
log-bin=mysql-bin
# 服务器唯一ID
server-id=1
log-bin: 开启binlog
server-id:指定服务器id(唯一,不能与slave服务器server-id相同)
重启mysql
sudo systemctl restart mysqld
查看master二进制文件名称和偏移量
show master status;
+------------------+----------+--------------+------------------+-------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+------------------+----------+--------------+------------------+-------------------+
| mysql-bin.000002 | 154 | | | |
+------------------+----------+--------------+------------------+-------------------+
此处二进制文件名称为:mysql-bin.000002,偏移量为:154
配置slave
修改my.cnf配置文件
sudo vim /etc/my.cnf
在/etc/my.cnf的[mysqld]下加入如下配置:
# 服务器唯一ID
server-id=2
# 开启中继日志
relay-log=slave-relay-bin
# 开启中继日志索引
relay-log-index=slave-relay-bin.index
# 设置只读
read_only=1
此处设置只读是因为,在主从复制的情况下,通常数据写入master,从slave中读取数据。
重启mysql
sudo systemctl restart mysqld
建立同步连接
CHANGE MASTER TO master_host = '192.168.8.134',
master_port = 3306,
master_user = 'repl',
master_password = 'L2019Mysql@',
master_log_file = 'mysql-bin.000002',
master_log_pos = 154;
master_host: master服务器ip
master_port: master上mysql服务端口
master_user: 配置master时创建的repl用户
master_password: master上repl用户密码
master_log_file: 配置master第5步查询到的二进制日志文件名称
master_log_pos: 配置master第5步查询到的偏移量
启动slave
start slave;
查看slave状态
show slave status \G
此时Slave_IO_Running、Slave_SQL_Running值都是Yes,说明主从复制配置成功

测试
在master上新建一个名为test的数据库
create database test;
在slave上查看
show databases;
可以看到test数据库已经同步到slave上了

可能出现的错误
- [ERROR] Slave I/O for channel '': Fatal error: The slave I/O thread stops because master and slave have equal MySQL server UUIDs; these UUIDs must be different for replication to work. Error_code: 1593
我在查看slave状态时,发现 Slave_IO_Running: No
查看日志
tail -f /var/log/mysqld.log
发现上面的错误。
原因:我在master: 192.168.8.134 上安装好mysql之后,使用克隆功能,创建了slave:192.168.8.135,导致master和slave上的server-uuid相同。
在master和slave上分别查看server-uuid
sudo cat /var/lib/mysql/auto.cnf
发现值都是:server-uuid=a1ae101b-13e3-11e9-8f07-000c29b2fc93
解决方法:
先重命名slave上的auto.cnf
sudo mv /var/lib/mysql/auto.cnf /var/lib/mysql/auto.cnf.bk
然后重启slave上的mysql
sudo systemctl restart mysqld
查看slave状态
show slave status \G
此时Slave_IO_Running、Slave_SQL_Running值都是Yes,说明主从复制配置成功

参考资料
centos7下配置mysql5.7.24主从复制的更多相关文章
- centos7下安装mysql5.7.24
第一步:下载rpm包 sudo wget http://repo.mysql.com/yum/mysql-5.7-community/el/7/x86_64/mysql57-community-rel ...
- Centos7 下配置mysql5.6主从复制实例(一主两从)
标签:mysql 数据库 原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://8941355.blog.51cto.com/89313 ...
- SVN CentOS7 下配置svn的安装及基础配置介绍
CentOS7 下配置svn的安装及基础配置介绍 by:授客 QQ:1033553122 目录 一. 二. 三. 四. 五. 六. 七. 一. 实践环境 CentOS 7操作系统(CentO ...
- Eclipse 下配置MySql5.6的连接池,使用Tomcat7.0
目前找到的最简单的配置方法. 1.首先在eclipse中创建一个Dynamical Web Application,在WebContent文件夹下的META-INF文件夹中创建新的名为conten ...
- Linux(CentOS7)下配置多个tomcat
记录 Linux(CentOS7) 下配置多个 tomcat 的操作过程. 一.下载tomcat 前提:安装配置好jdk环境,未配置可参考Linux(CentOS7)下安装jdk1.8. 从 tomc ...
- centos7中安装mysql5.6版本 + 主从复制
centos安装5.6版本:CentOS7下使用YUM安装MySQL5.6 主从复制:Mysql主从复制与读写分离原理及配置教程 主从复制问题及配置 卸载和安装5.7版本:CentOS 7 安装与卸载 ...
- CentOS7编译安装MySQL5.7.24
目录 安装依赖 安装boost 编译安装MySQL 配置 登录MySQL,修改密码 安装依赖 (1)cmake是新版MySQL的编译工具 sudo yum install gcc gcc-c++ pc ...
- Centos7 安装配置mysql5.6
Centos7下完美安装并配置mysql5.6 Centos7将默认数据库mysql替换成了Mariadb,对于我们这些还想用mysql的人来说并不是一个好消息. 最近我搜罗了网上各种安装教程,各 ...
- 日常工作问题解决:centos7下配置网卡以及查询网卡UUID
目录 1.配置网卡 1.1 网卡查看命令:ifconfig -a 1.2 网卡配置文件说明 1.3 重启网络服务 2.查看确认网卡UUID 2.1 网卡配置文件正常时 2.2 网卡配置文件不可用或者配 ...
随机推荐
- Python Requests库入门——应用实例-百度、360搜索关键词提交
百度的关键词接口: http://www.baidu.com/s?wd=keyword 360的关键词接口: http://www.so.com/s?q=keyword keyword就是需要查找的关 ...
- 作业要求20181016-3 Alpha阶段第1周/共2周 Scrum立会报告+燃尽图 01
此次作业要求参见https://edu.cnblogs.com/campus/nenu/2018fall/homework/2246 Scrum master:范洪达 一.小组介绍 组长:王一可 组员 ...
- Apache 的知识点
apache 的官方文档 http://httpd.apache.org/docs/ Mac下如何查看Apache的版本 在终端(Terminal)中输入 apachectl -v,之后回车,结果如下 ...
- OSG学习:使用OSG中预定义的几何体
常用的内嵌几何体包括: osg::Box //正方体 osg::Capsule //太空舱 osg::Cone //椎体 osg::Cylinder //柱体 osg::HeightField //高 ...
- jdbc 1.0
1. jdbc : java数据库连接技术 2.主要用到的类及接口 Class Driver ManagerDriver Connection Statement PreparedStatement ...
- n元一维向量向左循环移位i的几种算法
1.最简单的算法借助于一个n元的中间向量在n步时间内完成 时间复杂度:O(n) 空间复杂度O(n) void shift_easy(int arr[], int _arr[], int n, int ...
- JarvisOJ平台Web题部分writeup
PORT51 题目链接:http://web.jarvisoj.com:32770/ 这道题本来以为是访问服务器的51号端口,但是想想又不太对,应该是本地的51号端口访问服务器 想着用linux下的c ...
- Web服务器负载均衡的几种方案 : DNS轮询
本篇主要讲一下最简单的方案——DNS轮询. DNS轮询 大多域名注册商都支持多条A记录 的解析,其实这就是DNS轮询 ,DNS 服务器 将解析请求按照A记录 的顺序,逐一分配到不同的IP上,这样就完成 ...
- VS NuGet离线包(缓存包)nupkg安装
最近项目需要在NuGet添加一个依赖项,无奈公司开发机没网... 说出来各位看官可能不信,做开发的开发机居然没网!!!!!(那你还不赶快离职闪人) 没办法,项目需要还是得把东西扔进VS里面去,只有想办 ...
- (转)REST无状态的理解
转至http://lelglin.iteye.com/blog/1852092 Representational State Transfer的缩写.我对这个词组的翻译是"表现层状态转化&q ...