配置mysql5.7主从复制
admin
2023-02-25 02:20:05
0

一,配置主数据库

1, 修改my.cnf或者my.ini

                 [mysqld]

                 log-bin=mysql-bin

                 server-id=1

    修改完成,重启服务器

2, 注意:

1) 如果未设置server_id或者设置为0,那么主数据库将会拒绝所有从数据库的连接

2) 如果使用的是innodb存储引擎,为了获得更好的持久性与一致性,需要在my.cnf中配置如下选项:

           innodb_flush_log_at_trx_commit=1

           sync_binlog=1

3) 确保 主数据库skip_networking系统变量为不可用,否则,从服务器将无法连接主服务器,导致复制失败

3, 创建用于复制的用户

                  新建一个用户repl,赋予复制权限,专门用于主从复制。

                  mysql> CREATE USER 'repl'@'%.example.com' IDENTIFIED BY 'password';

                  mysql> GRANT REPLICATION SLAVE ON *.* TO 'repl'@'%.example.com';

4, 获取复制主二进制日志坐标

              1),在主库上新建会话,锁定表的写操作

                       mysql> FLUSH TABLES WITH READ LOCK;

                       警告:发出锁操作的客户机要保持连接,否则会释放锁。

             2),在主数据库上新建会话,查询二进制日志文件的名字和位置:

                      mysql > SHOW MASTER STATUS;

                      记下file一栏的名字和position一栏的位置,稍后配置从库会用到,如果主数据库没有在启用二进制日志文件的情况下运行,则查询结果可能为空,那么在稍后的从库配置中,名字为‘’空字符串,位置为4

5, 如果主库已经存在数据

      那么,不要断开锁表会话,然后进行下一步

      1),新建一个主库的快照

                         mysqldump--all-databases --master-data > dbdump.db

                         如果想忽略某几个库:

                         mysqldump --all-databases –ignore-database=db1 –ignore-database=db2 –ignore-database=db3 --master-data > dbdump.db

                         如果只想快照某个数据库db1:

                         mysqldump –databases database1 --master-data > dbdump.db

                         或者快照某几个数据库db1,db2,db3:

                          mysqldump –databases db1 db2 db3 --master-data > dbdump.db

                2),导入快照数据

                         mysql < dbdump.db   

                         可以复制快照文件到从服务器,或者远程访问该快照文件

二,设置复制从数据库,

1, 在主库上释放锁:

                 mysql> UNLOCK TABLES;

2, 编辑从库my.cnf,设置server-id,该id必须是唯一的,不可与主库或者任何从库冲突。

                 [mysqld]

                 server-id=2

                 设置完成,重启服务器

3, 注意:

                1)如果将server-id 设置为0,则从库为拒绝连接主库

                2)如果从库只是作为从库使用,就不必开启二进制日志,如果从库继续作为二级主库,则需要开启二进制日志

                3)复制不能使用Unix套接字文件。您必须能够使用TCP/IP连接到主MySQL服务器

4, 如果从库没有快照要导入:

1) 启动从库并连接

2) 运行从库设置语句

                  CHANGE MASTER TO

                  MASTER_HOST='master_host_name',

                  MASTER_USER='replication_user_name',

                  MASTER_PASSWORD='replication_password',

                  MASTER_LOG_FILE='recorded_log_file_name',

                  MASTER_LOG_POS=recorded_log_position;

3) 启动从库

     Start slave;

5, 如果从库需要导入快照数据:

1) 使用如下命令启动从库

                  mysqld  --skip-slave-start &

2) 导入快照:

                      mysql < dbdump.db      

3) 运行从库设置语句:

                      CHANGE MASTER TO

                      MASTER_HOST='master_host_name',

                      MASTER_USER='replication_user_name',

                      MASTER_PASSWORD='replication_password',

                      MASTER_LOG_FILE='recorded_log_file_name',

                      MASTER_LOG_POS=recorded_log_position;

4) 启动从库

                      start slave

      从属服务器在其主信息存储库中存储有关已配置的主服务器的信息。主信息存储库可以是文件或表的形式,这取决于从库的系统变量 master_info_repository 设置

      如果master_info_repository=FILE,那么,以文件master.info 和 relay-log.info的形式存在于data目录

      如果master_info_repository=TABLE ,那么,信息存在 master_slave_info表中。

      主信息存储库的内容会覆盖命令行或my.cnf中指定的一些服务器选项。


相关内容

热门资讯

伊朗确认前往美国参加世界杯:将... 当地时间5月6日,伊朗国家足球队主教练在接受采访时表示,伊朗国家足球队将于美加墨世界杯开始前14天抵...
雷达、机库、营房、燃料库、飞机... 据《华盛顿邮报》5月6日报道,通过卫星影像分析发现,自2月28日战事爆发以来,伊朗空袭已在中东美军军...
从买买买到租租租,“租用一代”... “五一”假期还在路上,年轻人已经“租”起来了。 “租三天,不到300块钱。”五一放假前一周,清清已给...
【品牌】摩托罗拉大折叠屏新机定... 此前联想预热将于5月19日19点举行联想天禧AI一体多端全场景新品超能之夜活动,届时将带来多款新品,...
常州欣隽益取得接线端子用快速冲... 国家知识产权局信息显示,常州欣隽益科技有限公司取得一项名为“接线端子用快速冲切装置”的专利,授权公告...
美媒:特朗普在结束伊朗战争问题... 据“国会山”网站5月6日报道,周二晚间,美国总统特朗普突然宣布终止旨在打破伊朗对霍尔木兹海峡掌控的军...
和创硅材料取得熔融石英制品擦洗... 国家知识产权局信息显示,东海县和创硅材料有限公司取得一项名为“一种熔融石英制品的擦洗脱泥装置”的专利...
美商务部长再就爱泼斯坦案接受国... 5月6日,美国商务部长卢特尼克“自愿”就其与爱泼斯坦的关系接受美国国会众议院监督与政府改革委员会的问...
“五一”小长假黄金零售市场新变... 【大河财立方 记者 孙凯杰】 “五一”小长假,黄金价格出现一波短暂调整,线下黄金零售市场热度如何?5...
以军3周来首次袭击黎巴嫩首都 据以色列总理内塔尼亚胡和国防部长卡茨当地时间5月6日晚发表的联合声明,以军当天对黎巴嫩首都贝鲁特南郊...