广告
返回顶部
首页 > 资讯 > 数据库 >2:基于二进制日志文件位置的复制
  • 649
分享到

2:基于二进制日志文件位置的复制

2024-04-02 19:04:59 649人浏览 薄情痞子
摘要

服务器 192.168.1.2 (master) ,服务器 192.168.1.3 (slave) 要将master配置为使用基于二进制日志文件位置的复制,必须启用二进制日志记录并建立唯一的server-

  1. 服务器 192.168.1.2 (master) ,服务器 192.168.1.3 (slave)
  2. 要将master配置为使用基于二进制日志文件位置的复制,必须启用二进制日志记录并建立唯一的server-id。要配置二进制日志和server ID选项,请关闭Mysql服务器并编辑my.cnf或my.ini文件。在配置文件的[mysqld]部分中,添加log-bin和server-id选项。如果这些选项已经存在,但是注释掉了,取消注释并根据您的需要修改它们。
  3. 在master上,打开对应的my.cnf
    2:基于二进制日志文件位置的复制
    • 重启mysql,进入mysql,查看对应的server_id是否设置成功
    • mysql> show variables like 'server_id';
    • +---------------+-------+
    • | Variable_name | Value |
    • +---------------+-------+
    • | server_id | 1 |
    • +---------------+-------+
    • 1 row in set (0.00 sec)
    • 表示设置是成功的
  4. 在master上,创建复制使用的用户(每个slave都使用MySQL用户名和密码连接到master,因此master必须有一个用户帐户可以让slave用来连接。任何帐户都可以用于此操作,只要授予它REPLICATioN SLAVE特权。)
    • 进入mysql,执行以下命令
    • mysql> CREATE USER 'lisi'@'%' IDENTIFIED BY 'Lisi@123456';
    • Query OK, 0 rows affected (0.00 sec)
    • mysql> GRANT REPLICATION SLAVE ON . TO 'lisi'@'%';
    • Query OK, 0 rows affected (0.00 sec)
    • 接下来通过FLUSH刷新所有表和块写入语句
    • mysql> FLUSH TABLES WITH READ LOCK;
    • Query OK, 0 rows affected (0.00 sec)
    • 然后确定当前的二进制日志文件名称和位置:
    • mysql> show master status;
    • +------------------+----------+--------------+------------------+-------------------+
    • | File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
    • +------------------+----------+--------------+------------------+-------------------+
    • | mysql-bin.000005 | 802858 | | | |
    • +------------------+----------+--------------+------------------+-------------------+
    • 1 row in set (0.00 sec)
  5. 在slave上,设置server_id,然后重启slave的mysql
    • 2:基于二进制日志文件位置的复制
  6. 在slave上,在slave上设置master配置
    • mysql> CHANGE MASTER TO MASTER_HOST='192.168.1.2', MASTER_USER='lisi', MASTER_PASSWord='Lisi@123456', MASTER_LOG_FILE='mysql-bin.000005',MASTER_LOG_POS=802858;
      • 参数讲解
      • MASTER_HOST master的ip地址
      • MASTER_USER master的复制用户名
      • MASTER_PASSWORD master的复制用户的密码
      • MASTER_LOG_FILE master的二进制文件
      • MASTER_LOG_POS master的二进制文件位置
  7. 在slave上,启动复制
    • mysql> start slave;
    • Query OK, 0 rows affected (0.00 sec)
    • 查看slave状态
    • mysql> show slave status\G
    • 2:基于二进制日志文件位置的复制
    • 可以查看这两个是Yes那就说明成功了
  8. 在master上
    • mysql> UNLOCK TABLES;
    • Query OK, 0 rows affected (0.00 sec)
  9. 下面就是在mysql中的数据库中随便操作一下数据,看下是否同步,如果同步则表示没有问题,有问题,请及时查看slave的mysql错误日志

注意:

  • 需要验证一下master的复制账号是否能远程登录
  • 复制组中的每个服务器必须配置唯一的server ID

这次操作踩的坑:

  • Q: Can't connect to MySQL Server on ‘server’ 在当前主机上 mysql -uUserName -p -h localhost 可以连接上 mysql -uUserName -p -h ‘ip地址' 连接不上
  • A:先按照https://dev.mysql.com/doc/refman/8.0/en/can-not-connect-to-server.html介绍的方法进行排查,最后还发现连接不上,如果是阿里云的服务器,那么可能就是防火墙把3306d端口给关了,那么就要在防火墙把这个端口给放开
  • 2:基于二进制日志文件位置的复制
  • 或者进入Https://help.aliyun.com/document_detail/25471.html?spm=a2c4e.11153987.0.0.2de65a75vopCz7进行设置
  • Q:在slave机器上mysql -uUserName -p -h ‘master的ip地址’ 可以连接上,但show slave status是下图
    *2:基于二进制日志文件位置的复制
  • A:查看错误日志
  • 2:基于二进制日志文件位置的复制
  • 2026是ssl错误,说明我们启动了ssl连接
  • 这时候需要在master和slave上的my.conf文件加上以下行
  • 2:基于二进制日志文件位置的复制
  • 然后重启mysql,如果在mysql中看到以下结果,就说明ssl被关闭了
  • 2:基于二进制日志文件位置的复制
  • 这时候如果slave还是连接不上master的话,我们再看一下show slave status的信息
  • 2:基于二进制日志文件位置的复制
  • 如果Master_SSL_Allowed为Yes,那么就要改为No,具体修改在change master语句里面改,本次我们的修改例子为
    CHANGE MASTER TO MASTER_HOST='192.168.1.2', MASTER_USER='lisi', MASTER_PASSWORD='Lisi@123456', MASTER_LOG_FILE='mysql-bin.000005',MASTER_LOG_POS=802858,master_ssl=0; 主要是master_ssl=0然后在执行一下start slave。

参考资料:https://dev.mysql.com/doc/refman/5.7/en/binlog-replication-configuration-overview.html

PREV:1:MySQL的复制原理 https://blog.51cto.com/itzhoujun/2352587

NEXT:3:添加一个slave到已有的复制环境 https://blog.51cto.com/itzhoujun/2351567

您可能感兴趣的文档:

--结束END--

本文标题: 2:基于二进制日志文件位置的复制

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

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

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

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

下载Word文档
猜你喜欢
  • 2:基于二进制日志文件位置的复制
    服务器 192.168.1.2 (master) ,服务器 192.168.1.3 (slave) 要将master配置为使用基于二进制日志文件位置的复制,必须启用二进制日志记录并建立唯一的server-...
    99+
    2022-10-18
  • 3:添加一个slave到已有的复制环境(基于二进制日志文件位置)
    服务器 192.168.1.2 (master) ,服务器 192.168.1.3 (old slave) 服务器 192.168.1.4 (new slave) 您可以将另一个slave添加到现有复...
    99+
    2022-10-18
  • 基于二进制文件的主从复制
    1.设置主服务器配置         必须在主服务器上启用二进制日志,因为二进制日志是将更改从主服务器复制到从服务器的基础,如果未启用log-bin,则无法进行复制         复制组内的每个服务器必须配置有唯一的id,此id...
    99+
    2021-08-12
    基于二进制文件的主从复制
  • mysql中二进制日志文件报错的示例分析
    这篇文章给大家分享的是有关mysql中二进制日志文件报错的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1、可以通过如下设置,自动删除日志文件,需要重启mysqlvim /etc/my.cnf&...
    99+
    2023-06-15
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作