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

发布时间:2020-07-16 23:26:37 作者:shixiazhoujun
来源:网络 阅读:335
  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错误日志

注意:

这次操作踩的坑:

参考资料: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

推荐阅读:
  1. MySQL 存储过程的三种类型和函数讲义
  2. 获取MySQL整体性能的状态

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

mysql 主从复制 基于二进制位置

上一篇:struts2的执行过程

下一篇:循环程序设计实验

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》