提高性能,MySQL 读写分离环境搭建(二)

举报
江南一点雨 发表于 2021/08/17 00:00:51 2021/08/17
【摘要】 点击上方 牧码小子 ,选择 置顶或者星标原创技术干货每日送达! 上篇文章和大家聊了 CentOS7 安装 MySQL5.7 ,这个大家一般装在虚拟机里边,装好了,把虚拟拷贝一份,这样我们就有两个 MySQL ,就可以开始今天的主从搭建了。 注意 CentOS 上安装 MySQL 是基础,如果大家尚未在 CentOS 上安装过 MySQL ,可以先...

点击上方 牧码小子 ,选择 置顶或者星标原创技术干货每日送达!

上篇文章和大家聊了 CentOS7 安装 MySQL5.7 ,这个大家一般装在虚拟机里边,装好了,把虚拟拷贝一份,这样我们就有两个 MySQL ,就可以开始今天的主从搭建了。

注意 CentOS 上安装 MySQL 是基础,如果大家尚未在 CentOS 上安装过 MySQL ,可以先阅读本文的姊妹篇:提高性能,MySQL 读写分离环境搭建(一)。

准备工作

我这里有一张简单的图向大伙展示 MySQL 主从的工作方式:

640?wx_fmt=png

这里,我们准备两台机器:

•主机:192.168.248.128•从机:192.168.248.139

主机配置

主机的配置就三个步骤,比较容易:

1.授权给从机服务器

 
 

   
  1. GRANT REPLICATION SLAVE ON *.* to 'rep1'@'192.168.248.139' identified by '123';
  2. FLUSH PRIVILEGES;

这里表示配置从机登录用户名为 rep1,密码为 123,并且必须从 192.168.248.139这个地址登录,登录成功之后可以操作任意库中的任意表。其中,如果不需要限制登录地址,可以将 IP 地址更换为一个 %

2.修改主库配置文件,开启 binlog ,并设置 server-id ,每次修改配置文件后都要重启 MySQL 服务才会生效

 
 
vi /etc/my.cnf
  

修改的文件内容如下:

 
 

   
  1. [mysqld]
  2. log-bin=/var/lib/mysql/binlog
  3. server-id=128
  4. binlog-do-db = cmdb

如下图:

640?wx_fmt=png

•log-bin:同步的日志路径及文件名,一定注意这个目录要是 MySQL 有权限写入的(我这里是偷懒了,直接放在了下面那个datadir下面)。•binlog-do-db:要同步的数据库名,当从机连上主机后,只有这里配置的数据库才会被同步,其他的不会被同步。•server-id: MySQL 在主从环境下的唯一标志符,给个任意数字,注意不能和从机重复。

配置完成后重启 MySQL 服务端:

 
 
systemctl restart mysqld
  

3.查看主服务器当前二进制日志名和偏移量,这个操作的目的是为了在从数据库启动后,从这个点开始进行数据的恢复:

 
 
show master status;
  

640?wx_fmt=png

至此,主机配置完成。

从机配置

从机的配置也比较简单,我们一步一步来看:

1.在/etc/my.cnf 添加下面配置:

640?wx_fmt=png

注意从机这里只需要配置一下 server-id 即可。

注意:如果从机是从主机复制来的,即我们通过复制 CentOS 虚拟机获取了 MySQL 实例 ,此时两个 MySQL 的 uuid 一样(正常安装是不会相同的),这时需要手动修改,修改位置在 /var/lib/mysql/auto.cnf ,注意随便修改这里几个字符即可,但也不可太过于随意,例如修改了 uuid 的长度。

2.使用命令来配置从机:

 
 
change master to master_host='192.168.248.128',master_port=3306,master_user='rep1',master_password='123',master_log_file='binlog.000001',master_log_pos=120;
  

这里配置了主机地址、端口以及从机登录主机的用户名和密码,注意最后两个参数要和 master 中的保持一致。

3.启动 slave 进程

 
 
start slave;
  

启动之后查看从机状态:

 
 
show slave status\G;
  

640?wx_fmt=png

4.查看 slave 的状态

主要是下面两项值都要为为 YES,则表示配置正确:

 
 

   
  1. Slave_IO_Running: Yes
  2. Slave_SQL_Running: Yes

至此,配置完成,主机创建库,添加数据,从机会自动同步。

如果这两个有一个不为 YES ,表示主从环境搭建失败,此时可以阅读日志,查看出错的原因,再具体问题具体解决。

总结

本文主要和大伙说了 MySQL 主从环境搭建,这几个步骤松哥反反复复操作过很多遍,小伙伴只要按照松哥的步骤一般来说都能成功,有问题欢迎留言讨论。


640 640关注牧码小子,后台回复 Java ,领取松哥为你精心准备的Java干货! 640

往期文章一览

1、天呐,我的服务器竟然也被黑客攻击了!

2、两年了,我写了这些干货!

3、想和大家谈一点合作

4、一个Java程序猿眼中的前后端分离以及Vue.js入门

5、跟着平台混了四年,现在要单飞了!

640?wx_fmt=png你点的每个在看,我都认真当成了喜欢


文章来源: wangsong.blog.csdn.net,作者:_江南一点雨,版权归原作者所有,如需转载,请联系作者。

原文链接:wangsong.blog.csdn.net/article/details/99543830

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。