Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 324|回复: 0

Mycat分布式数据库架构解决方案--搭建MySQL读写分离环境--一主多从

[复制链接]
  • TA的每日心情
    奋斗
    2024-11-24 15:47
  • 签到天数: 804 天

    [LV.10]以坛为家III

    2053

    主题

    2111

    帖子

    72万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    726782
    发表于 2021-5-19 14:02:04 | 显示全部楼层 |阅读模式

    echo编辑整理,欢迎转载,转载请声明文章来源。欢迎添加echo微信(微信号:t2421499075)交流学习。 百战不败,依不自称常胜,百败不颓,依能奋力前行。——这才是真正的堪称强大!!!


    本文主要为了记录MySQL搭建读写分离的操作,是本人的操作纪实,并没有详细讲解其中的原理和操作设置,如果需要详细解释的,不建议阅读。

    环境准备:

    linux系统版本 对应服务器地址 数据库 版本
    CentOS7 192.168.222.132 MySQL 5.6
    CentOS7 192.168.222.133 MySQL 5.6
    CentOS7 192.168.222.134 MySQL 5.6

    第一步:建立时间同步环境

    • 使用yum安装npt
    yum install ntp –y
    
    • 安装完成之后修改ntp对应的配置文件
    vi /etc/ntp.conf
    
    • 添加如下配置:图片中地址,对应我们自己服务器的地址
    restrict 192.168.222.132 mask 255.255.255.0 nomodify notrap
    server 127.127.1.0
    fudge 127.127.1.0 stratum 8
    

    在这里插入图片描述

    • 启动ntp服务
    systemctl start ntpd
    
    • 检验ntp是否成功安装运行,如果正常工作我们可以得到如下信息
    ntpq -p
    

    在这里插入图片描述

    将我们三台服务全部做以上配置,配置完成之后,我们就可以开始设置主mysql服务器了

    第二步:配置 MySQL 主服务器

    • 打开my.cnf配置文件,进行如下配置
    # 打开文件
    vi /etc/my.cnf
    

    找到配置文件中的这一段,然后按照下面的配置进行修改
    在这里插入图片描述

    server-id=132   # 使用ip的后端作为我们的主服务id
    log_bin=mysql-bin  # 开启MySQ二进制日志系统。
    
    • 登录mysql,然后获取数据库列表
    mysql -uroot -P3306 -p123456 -h192.168.222.132
    
    show databases;
    

    在这里插入图片描述

    binlog-do-db=test  # 需要同步的数据库名test,其他的数据库不同步。
    binlog-ignore-db=mysql   #不同步mysql系统数据库,每一个数据库对应一行。
    binlog-ignore-db=information_schema
    binlog-ignore-db=performance_schema
    
    • 配置完成,重复服务
    service mysql restart
    
    • 查看我们的配置是否成功
    show master status;
    

    在这里插入图片描述

    如果显示结果和我们配置一致证明我们的主服务器配置已经成功啦!可以进行从服务器的配置

    配置从服务器

    • 打开my.cnf配置文件,进行如下配置
    # 打开文件
    vi /etc/my.cnf
    

    找到配置文件中的这一段,然后按照下面的配置进行修改
    在这里插入图片描述

    server-id=133   # 使用ip的后端作为我们的主服务id
    log_bin=mysql-bin  # 开启MySQ二进制日志系统。
    
    • 登录mysql,然后获取数据库列表
    mysql -uroot -P3306 -p123456 -h192.168.222.133
    
    show databases;
    

    在这里插入图片描述

    binlog-do-db=test  # 需要同步的数据库名test,其他的数据库不同步。
    binlog-ignore-db=mysql   #不同步mysql系统数据库,每一个数据库对应一行。
    binlog-ignore-db=information_schema
    binlog-ignore-db=performance_schema
    
    • 配置完成,重复服务
    service mysql restart
    

    从服务器需要做的关键操作

    • 为从服务器创建一个可以登录主服务器的账号。
    # 登录主服务器,创建一个新账号
    GRANT REPLICATION SLAVE ON *.* TO 'slave'@'192.168.222.133' IDENTIFIED BY '123456';
    # 刷新权限
    FLUSH PRIVILEGES;
    
    • 然后使用root用户连接mysql,再执行一下语句
    change master to
    master_host='192.168.222.132',
    master_user='slave',
    master_password='123456',
    master_log_file='mysql-bin.000011',
    master_log_pos=1243;
    
    • 配置完成之后,启动从服务器
    start slave;
    
    • 查看从服务器启动状态
    show slave status \G;
    

    在这里插入图片描述
    出现上面这两个“Yes”就证明已经配置成功了

    • 如果发现配置不对,需要先停掉从服务器
    stop slave;
    
    • 然后重置从服务器
    reset slave;
    

    采坑解决

    在这里插入图片描述
    如果出现如上报错,我们需要先停止从服务器。该问题引起的原因是我之前安装数据库的时候并没有发现他们的版本不一致导致的,停机更新版本之后再次按照下面步骤操作就好了。

    # 先停掉从服务器
    stop slave;
    # 重置从服务器
    reset slave;
    # 然后排查配置的问题,重新配置一遍
    change master to
    master_host='192.168.222.132',
    master_user='slave',
    master_password='123456',
    master_log_file='mysql-bin.000011',
    master_log_pos=709;
    # 再次启动
    start slave;
    # 查看服务器状态
    show slave status \G;
    

    尝试创建一个表,查看是否同步

    CREATE TABLE `user` (
      `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '自增id',
      `user_name` varchar(255) DEFAULT NULL,
      `pass_word` varchar(255) DEFAULT NULL,
      PRIMARY KEY (`id`)
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
    

    在这里插入图片描述

    到这里我们已经成功啦!


    注意:

    我们配置第三台服务的时候,需要从新创建一个给第三台服务器访问的主服务器的账号。同时,由于我们是在本地虚拟机上安装的读写分离环境,所以每一次启动mysql或者关闭虚拟机都会导致mysql的position改变,所以我们要跟随着配置变化,每次启动读写环境前检查一下,修改配置和上面采坑解决的步骤一直。


    做一个有底线的博客主

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-1-23 06:00 , Processed in 0.055082 second(s), 27 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表