广告
返回顶部
首页 > 资讯 > 数据库 >mysql基于日志的主从复制是什么
  • 251
分享到

mysql基于日志的主从复制是什么

2024-04-02 19:04:59 251人浏览 八月长安
摘要

这篇文章主要介绍了Mysql基于日志的主从复制是什么,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让小编带着大家一起了解一下。      

这篇文章主要介绍了Mysql基于日志的主从复制是什么,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让小编带着大家一起了解一下。

                                                       

总有人问我 会不会读写分离,我有时真的不知道怎么回答,这么滴吧,技术本身不难你,难的是咱们能不能遇得到这么大的项目。如果是真有这么大项目,光读写分离这个事肯定不是一两个人在搞,应该是多人协作的。

所以呢!我没搞过。

但是……

不能做实验环境吗?(一个尴尬的笑容)

我从找文档资料到实验落地,一共花了3天时间(因为不是全天都在围绕着这个事情哇)。基本搞定,就是说,如果有人问我会不会,我说我已经操作过了,不是什么难事。

具体注意点:


  1. 主从之间的防火墙需要放行
  2. mysql-id 得唯一 见 my.cnf
  3. uuid 得唯一 见 auto.cnf
  4. 服务器要授权,一般授权一个slave账号给从服务器使用

常用几个命令(针对日志的方式)


  1. 在主库上操作的有

    mysql > show master status; #查看主库状态

    mysql >  grant replication slave on . to ‘slave‘@’%ip%’ identified by ‘passWord’;#  to 后面的 解释: ‘slave’ 代表哪个账户,@后面的是从服务器的IP by 后面的是密码;

    systemctl status firewalld # 查看防火墙状态

    firewall-cmd –list-all # 查看防火墙的端口列表

    firewall-cmd –permanent –zone=public –add-port=3306/tcp # 放行 3306 端口

    firewall-cmd –reload  # 重启防火墙

    另外 iptable 的话 可以自行看看哇

  2. 在从库上操作主要有

    1. mysql>  stop slave; // 停止复制
    2. mysql>  reset slave; // 重置复制
    3. mysql>  start slave; // 开启复制
    4. mysql> show slave status\G; # 查看状态

具体配置


  1. 环境介绍

    1. 主服务器  192.168.5.238   Centos 7.4
    2. 从服务器 192.168.5.239    centos 7.4
    3. 利用日志来进行主从配置
  2. 主服务器上的配置

    1. 防火墙操作,防止后面出奇怪的问题 参考常用几个命令的防火墙操作

    2. mysql 的日志相关的配置  其他的先不用动 主要是看这段

      # aster live copy configure
      log-bin=mysql-bin  //日志文件名
      binlog_fORMat=mixed  // 这个日志格式,还有几个选项,大家都选mixed  可选项statement/row/mixed,如果想深究 可以去看官方文档
      server-id   = 238 //为了不重复使用 尽量采用服务器IP 的最后一位来命名
      skip_name_resolve=ON //这个直接写上就可以了,参考一下别人的文档
      expire_logs_days = 10 //设置日志保存的天数,这个吧 我觉得可以不用加,加上也无所谓,因为在测试环境,如果正式上线跑的话,就要掂量一下了
      # /etc/init.d/mysql restart // 这个不一定是这个命令 看自己是用什么方式安装的 centos 也有 systemctl restart mysql的 这个不懂可以多研究一下linux操作
      ##如果两台服务器不是复制的话,auto.cnf 的uuid应该会不一样,如果是复制的话,就该看看了,这个在mysql的安装目录的 /var、目录下如果有 就把这个文件删除或者mv 备份一下

  3. mysql配置一下复制权限

    # mysql -uroot -p “password” //登入mysql服务器、会让你输入密码
      mysql>GRANT replication slave ON . TO ‘slave‘@’%’ IDENTIFIED BY ‘111111’; // 解释 replication 分配复制的权限 这个. 可以操作那个库  后面的‘slave‘@’%’ 表示任何主机用slave都可以进行从库复制,也可以指定到IP 后面就是密码哈
      mysql> show master status;
      +——————+———-+————–+——————+——————-+
      | File             | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
      +——————+———-+————–+——————+——————-+
      | mysql-bin.000010 |     2812 |              |                  |                   |
      +——————+———-+————–+——————+——————-+
      1 row in set (0.00 sec)
      看到上面的这个表表示成功了

  4. 从库上的配置

    1. 修改my.cnf

      log-bin=mysql-bin  //日志文件名
      binlog_format=mixed //日志格式
      server-id   =239    //服务器ID 这个和主服务器一个解释,用IP的尾巴
      # expire_logs_days = 10  //这个我注释掉了,
      # early-plugin-load = “” //这个暂时没有使用,如果启用可以配置此项,主从复制这个项并不是关键项
      relay_log = mysql-relay-bin //这个是个从库的复制日志
      relay_log_index=relay_log.index //日志索引
      # /etc/init.d/mysql restart // 这个不一定是这个命令 看自己是用什么方式安装的 centos 也有 systemctl restart mysql的 这个不懂可以多研究一下linux操作

    2. 设置从库

      1. 进入从库的mysql 终端  #mysql -uroot -p //进入终端

        # mysql -uroot -p //进入终端(之所以写详细点,就是怕看到此文的人会误会操作不全)

      2. 关闭slave  # 注意配置从库之前先关闭掉slave;

        mysql>stop slave;  //这个是关闭从库哇,保证一把过

      3. 修改master参数

        mysql>change master to
        master_host=’192.168.5.238’,
        master_user=’slave’,
        master_password=’这里填上面设置主库复制权限时的密码’,
        master_log_file=’mysql-bin.000010’, //这里填 在主库 show master status 的文件名,位置对着抄就好了
        master_log_pos=2812; //在主库的show master status 里找

      4. 启动从库

        mysql>start slave; //启动从库

      5. 查看主从复制是否成功

        mysql> show slave status \G;

                 Slave_IO_State: Waiting for master to send event
                      Master_Host: 192.168.5.238
                      Master_User: slave
                      Master_Port: 3306
                    Connect_Retry: 60
                  Master_Log_File: mysql-bin.000010
              Read_Master_Log_Pos: 2812
                   Relay_Log_File: mysql-relay-bin.000013
                    Relay_Log_Pos: 3025
            Relay_Master_Log_File: mysql-bin.000010
                 Slave_IO_Running: Yes
                Slave_SQL_Running: Yes

        看到 Slave_IO_Running 和 Slave_SQL_Running 值 都为 Yes  说明就成功了,如果不成,请看下面的提示信息,对着谷歌 百度 应该能找出来的

        1. 我在配置时遇到了一个问题,就是报uuid错误,原因是我的实验环境是一个虚拟机安装完mysql后复制的,所以导致mysql的uuid 相同了

          # cd /usr/local/mysql/var
          # mv auto.cnf auto.cnf.back //这个你看有没有,没有就不操作,有就这样
          #  /etc/init.d/mysql restart  //重启数据库
          然后执行show slave status\G;观察两个yes

        2. 至此,基于日志的主从复制就完成了

总结


  1. 防火墙 要先看
  2. 步骤无所谓,对着搞,直到成功
  3. 细心,不能慌

感谢你能够认真阅读完这篇文章,希望小编分享mysql基于日志的主从复制是什么内容对大家有帮助,同时也希望大家多多支持编程网,关注编程网数据库频道,遇到问题就找编程网,详细的解决方法等着你来学习!

您可能感兴趣的文档:

--结束END--

本文标题: mysql基于日志的主从复制是什么

本文链接: https://www.lsjlt.com/news/49990.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • mysql基于日志的主从复制是什么
    这篇文章主要介绍了mysql基于日志的主从复制是什么,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让小编带着大家一起了解一下。       ...
    99+
    2022-10-18
  • mysql主从复制配置(日志点)
            一些mysql版本并不会开启二进制日志,所以一定要检查是否开启。如果一开始没开启,在以后需要开启,则必须重启数据库服务器,而数据库服务器重启会对业务造成很大影响。所以,尽管二进制日志会对性能...
    99+
    2022-10-18
  • 基于 SSL 实现MySQL主从复制
    1、主服务器配置1)、在主服务器创建SSL/RSA文件 #在MySQL5.7之后,安装完毕MySQL会在data目录下自动生成,这里模拟没有这些文件 [[email protected] ~]# mysql_ssl_rsa_setup...
    99+
    2016-06-28
    基于 SSL 实现MySQL主从复制 数据库入门 数据库基础教程 数据库 mysql
  • MySQL基于SSL协议的主从复制
       数据对于大部分公司来说都是最重要的部分,而MySQL的服务器在同步数据时,默认是使用明文进行传输,所以接下来就来说说MySQL基于SSL协议进行密文传输数据的主从复制模式。逻辑拓...
    99+
    2022-10-18
  • MySQL 5.7 基于GTID搭建主从复制
    MySQL 5.7 基于GTID搭建主从复制    一、搭建过程 1.1 准备三个MySQL实例 mysqld --initialize-insecure --use...
    99+
    2022-10-18
  • Mysql 主从复制之半同步复制(基于gtid)
    Mysql主从复制mysql主从复制原理:从库有两个线程IO线程和SQL线程1.从库的IO线程向主库的主进程发送请求,主库验证从库,交给主库IO线程负责数据传输;2.主库IO线程对比从库发送过来的maste...
    99+
    2022-10-18
  • MySql主从复制是什么
    小编给大家分享一下MySql主从复制是什么,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!一、什么是Mysql主从复制MySQL主从复制是其最重要的功能之一。主从复制是指一台服务器充当主数据库服...
    99+
    2022-10-18
  • 什么是MySQL主从复制
    这篇文章主要介绍“什么是MySQL主从复制”,在日常操作中,相信很多人在什么是MySQL主从复制问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”什么是MySQL主从复制”的疑惑...
    99+
    2022-10-18
  • 一文详解MySQL Binlog日志与主从复制
    目录1. Binlog日志的介绍2. 主从复制2.1 主从复制的流程2.2 GTID2.3 复制模型2.4 MGR模式2.5 并行回放1. Binlog日志的介绍 Binlog是Bi...
    99+
    2022-11-13
    MySQL Binlog日志 MySQL 主从复制
  • MySQL:安装和基于SSL加密的主从复制(基于5.7)
       小生博客:http://xsboke.blog.51cto.com             ...
    99+
    2022-10-18
  • 如何搭建基于Docker的MySQL主从复制
    下文主要给大家带来如何搭建基于Docker的MySQL主从复制,希望这些内容能够带给大家实际用处,这也是我编辑如何搭建基于Docker的MySQL主从复制这篇文章的主要目的。好了,废话不多说,大家直接看下文...
    99+
    2022-10-18
  • mysql之 MySQL 主从基于 GTID 复制原理概述
    一、 什么是GTID ( Global transaction identifiers ): MySQL-5.6.2开始支持,MySQL-5.6.10后完善,GTID 分成两部分,一部分是服务的UUid...
    99+
    2022-10-18
  • mysql之 MySQL 主从基于position复制原理概述
    1 、主从复制简介 MySQL 主从复制就是将一个 MySQL 实例(Master)中的数据实时复制到另一个 MySQL 实 例(slave)中,而且这个复制是一个异步复制的过程。 实现整个复制操作主要...
    99+
    2022-10-18
  • 基于GTID的主从复制搭建
    前置检查server-id = 10,master/slave不允许重复log-bingtid-mode = ONenforce-gtid-consistency = ON1,利用mysqlpump复制ma...
    99+
    2022-10-18
  • MySql之基于ssl安全连接的主从复制
    MySql基于ssl安全连接的主从复制一、设备环境centos7.2   两台MySQL 5.7MySQL 5.7 主要特性:原生支持Systemd更好的性能:对于多...
    99+
    2022-10-18
  • 基于二进制文件的主从复制
    1.设置主服务器配置         必须在主服务器上启用二进制日志,因为二进制日志是将更改从主服务器复制到从服务器的基础,如果未启用log-bin,则无法进行复制         复制组内的每个服务器必须配置有唯一的id,此id...
    99+
    2021-08-12
    基于二进制文件的主从复制
  • MySQL的主从复制原理是什么
    这篇“MySQL的主从复制原理是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“MySQL的主从复制原理是什么”文章吧。前...
    99+
    2023-07-02
  • mysql主从复制的原理是什么
    mysql主从复制的原理是什么?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。1、说明主从复制,是用来建立一个和主数据库完全一样的数据库环境,称为从数据库;主数据...
    99+
    2023-06-15
  • mysql主从复制策略是什么
    这篇文章主要介绍“mysql主从复制策略是什么”,在日常操作中,相信很多人在mysql主从复制策略是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”mysql主从复制策略是什么”的疑惑有所帮助!接下来,请跟...
    99+
    2023-06-20
  • 通过 mysqldump 搭建基于 gtid MySQL 5.7 主从复制
    安装主从 MySQL 5.7 # 主 MySQL5.7 useradd mysql /sbin/nologin cd /usr/local tar -xvf mysql-5.7.23-linux-glibc...
    99+
    2022-10-18
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作