Mysql主主复制配置
admin
2023-04-22 01:03:01
0

在主主复制结构中,两台服务器的任何一台上面的数据库存发生了改变都会同步到另一台服务器上,这样两台服务器互为主从,并且都能向外提供服务。配置的时候需要注意:主键重复,server-id不能重复。
1.新建数据库
Ubuntu16.04,开启两个虚拟机。
配置前,两个mysql分别新建一个数据库,保证的test数据库的数据一致
create database test default character set utf8 default collate utf8_general_ci;
2.修改配置文件
vim /etc/mysql/mysql.conf.d/mysqld.cnf
服务器A(192.168.8.129)配置如下
bind-address = 0.0.0.0
log_bin = /var/log/mysql/mysql-bin.log #开启二进制日志
server-id = 1 #任意自然数n,只要保证两台MySQL主机不重复即可
expire-logs-days = 100
replicate-do-db = test #要同步的数据库,默认所有库
binlog-ignore-db = mysql #忽略mysql库
binlog-ignore-db = information_schema #忽略information_schema库
auto-increment-increment = 2 #步进值,有n台主MySQL就填n
auto-increment-offset = 1 #起始值。第n台主MySQL,此时为第1主MySQL

服务器B(192.168.8.131)配置
bind-address = 0.0.0.0
log_bin = /var/log/mysql/mysql-bin.log
server-id = 2
expire-logs-days = 100
replicate-do-db = test
binlog-ignore-db = mysql
binlog-ignore-db = information_schema
auto-increment-increment = 2
auto-increment-offset = 2 #起始值,第2台主MySQL
二者只有server-id不同和 auto-increment- offset不同
auto-increment-offset是用来设定数据库中自动增长的起点的,两个服务器都设定了一次自动增长值2,所以它们的起点必须得不同,这样才能避免两台服务器数据同步时出现主键冲突
replicate-do-db 指定同步的数据库,我们只在两台服务器间同步test数据库。auto-increment-increment的值应设为整个结构中服务器的总数,本例用到两台服务器,所以值设为2
3.重启mysql服务
/etc/init.d/mysql restart
4.创建共享用户
创建一个可以在另一台主机上登录的MySQL用户repl
看是否有mysql中是否有repl这个用户
use mysql;
select user from user;
Mysql主主复制配置
若没有的话,新建用户
create user 'repl'@'%' IDENTIFIED BY 'passwd';
grant replication slave on . to 'repl'@'%';
flush privileges;
查看repl用户的权限
show grants for 'repl'@'%';
Mysql主主复制配置
5.测试是否能够远程登录
在服务器A上(192.168.8.129)
mysql -h 192.168.8.131 -u repl –p
输入口令jvkpxdYrlz
若成功,则继续下一步
若失败,检查mysqld.cnf文件中的配置,可能因为bind-address=127.0.0.1导致,使得仅允许本机访问。

  1. 分别查看二进制日志名和位置
    show master status;
    Mysql主主复制配置
  2. 相互授权用户
    在两台服务上分别先停止slave
    stop slave;
    在服务器A上(192.168.8.129)
    change master to MASTER_HOST='192.168.8.131',MASTER_USER='repl', MASTER_PASSWORD= 'passwd', MASTER_LOG_FILE='mysql-bin.000002', MASTER_LOG_POS=154;
    在服务器B上(192.168.8.131)
    change master to MASTER_HOST='192.168.8.129',MASTER_USER='repl', MASTER_PASSWORD= 'passwd', MASTER_LOG_FILE='mysql-bin.000002', MASTER_LOG_POS=154;
    再启动slave
    start slave;
    8.查看slave状态
    show slave status \G;
    正确结果如下图所示:
    Mysql主主复制配置
    可能出现的情况:
    (1) 当配置完成Slave_IO_Running、Slave_SQL_Running不全为YES时,show slave status\G信息中有错误提示,可根据错误提示进行更正。
    (2) Slave_IO_Running、Slave_SQL_Running不全为YES时,大多数问题都是数据不统一导致。
    (3) stop slave后,数据变更,再start slave,出错。重新执行一遍CHANGE MASTER即可。
    (4) 若出现如下图所示错误2003,连接不通过,则说明mysqld.cnf 中的bind_address未修改为0.0.0.0。如果要让mysql监听到其他的地址,可以将bind-address = 127.0.0.1注释掉,或者将bind-address = 0.0.0.0监听所有的地址
    Mysql主主复制配置
    (5) 若出现如下图所示错误1045,则说明配置change maseter时输入的repl用户的口令错误
    Mysql主主复制配置
    9.测试是否同步成功
    在A上
    create table test_user (id int NOT NULL AUTO_INCREMENT PRIMARY KEY,createtime datetime NOT NULL DEFAULT CURRENT_TIMESTAMP);
    在B上可以看到新增了一个表
    Mysql主主复制配置
    在B上
    insert into test_user set id=1;
    在A上可以看到test_user表中新增了一条记录。
    Mysql主主复制配置

参考网址https://www.cnblogs.com/zping/p/5315827.html
https://www.cnblogs.com/phpstudy2015-6/p/6485819.html#_label7

相关内容

热门资讯

珠海冠宇获得发明专利授权:“一... 证券之星消息,根据天眼查APP数据显示珠海冠宇(688772)新获得一项发明专利授权,专利名为“一种...
大华申请数据写入方法专利,提高... 国家知识产权局信息显示,浙江大华技术股份有限公司申请一项名为“数据写入方法、电子设备及计算机可读存储...
现在,赖清德更焦虑了 执笔/月半刀&宝刀刀&胡一刀5月13日,美国总统特朗普将开启访华行程。外界高度关注此次会晤中双方将如...
燃气发电与电池储能相结合,成为... 来源:市场资讯 (来源:i商周) 孟菲斯一座xAI数据中心的燃气轮机 人工智能的用电飙升,让数据中心...
景嘉微:JM11性能大幅提升,... 有投资者在互动平台向景嘉微提问:“董秘您好!关注到近期有用户反馈公司JM11显卡推出了适配windo...
原创 v... 影像的发展进一步推动,不少品牌推出了专业影像手机,拥有2亿像素摄像头、色彩还原摄像头、影像芯片、影像...
荣耀首款自研耳夹式耳机官宣即将... 快科技5月13日消息,日前,荣耀首席营销官关海涛宣布,荣耀全场景团队自研首款耳夹式耳机马上上市,并称...
谷歌推出Googlebooks... IT之家 5 月 13 日消息,2026 年 I/O 开发者大会下周(5 月 19~20 日)召开之...
自控所推动GNC专业智能化升级 来源:滚动播报 (来源:中国航空报) 本报讯 5月6日,航空工业自控所召开 GNC+AI关键技术研发...
华电电力申请数据库访问方法专利... 国家知识产权局信息显示,华电电力科学研究院有限公司申请一项名为“数据库访问方法、装置、设备及介质”的...