千家信息网

mysql中怎么实现主主同步

发表于:2025-02-02 作者:千家信息网编辑
千家信息网最后更新 2025年02月02日,本篇文章为大家展示了mysql中怎么实现主主同步,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。A服务器:host 192.168.1.101port 3306
千家信息网最后更新 2025年02月02日mysql中怎么实现主主同步

本篇文章为大家展示了mysql中怎么实现主主同步,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

A服务器:
host 192.168.1.101
port 3306
B服务器:
host 192.168.1.102
port 3306

1,授权用户:
A服务器
mysql>grant replication slave,file on *.* to identified by '1234569';
Query OK, 0 rows affected (0.01 sec)
mysql> flush privileges;
Query OK, 0 rows affected (0.01 sec)
B服务器
mysql>grant replication slave,file on *.* to identified by '1234568';
Query OK, 0 rows affected (0.01 sec)
> flush privileges;
Query OK, 0 rows affected (0.01 sec)

2,配置文件
A服务器
log-bin=mysql-bin
server-id = 1
binlog-do-db=test
binlog-ignore-db=mysql
replicate-do-db=test
replicate-ignore-db=mysql
log-slave-updates
slave-skip-errors=all
sync_binlog=1
auto_increment_increment=2
auto_increment_offset=1
master-host = 192.168.1.102
master-user = repl8
master-password = 1234568
master-port = 3306

B服务器

log-bin=mysql-bin
server-id = 2
binlog-do-db=test
binlog-ignore-db=mysql
replicate-do-db=test
replicate-ignore-db=mysql
log-slave-updates
slave-skip-errors=all
sync_binlog=1
auto_increment_increment=2
auto_increment_offset = 2
master-host = 192.168.1.101
master-user = repl9
master-password = 1234569
master-port = 3306


启动服务器就ok了


--------------------------------------------------
Q: 当在另一台机器上登录MySQL时出现如下错误:

ERROR 2003 (HY000): Can't connect to MySQL server on 'x.x.x.x' (111)

A: 原因是MySQL考虑到安全因素,默认配置只让从本地登录

打开 /etc/mysql/my.cnf 文件,找到 bind-address = 127.0.0.1 修改为 bind-address = 0.0.0.0

重启mysql : sudo /etc/init.d/mysql restart


========================================
101 增加,102不同步 ?????????
mysql -h292.168.1.102 -urepl8 -p1234568 ok

102 增加,101 同步
mysql -h292.168.1.101 -urepl9 -p1234569 ok

比较两组的show slave status\G;
102

Slave_IO_Running: No
Slave_SQL_Running: Yes
Replicate_Do_DB: test
Replicate_Ignore_DB: mysql


sudo /etc/init.d/mysql restart
sudo service mysql restart 以后就变成:lave_IO_Running: YES



出现的问题(多主自增长ID重复)

解决方法:
我们只要保证两台服务器上插入的自增长数据不同就可以了
如:A查奇数ID,B插偶数ID,当然如果服务器多的话,你可以定义算法,只要不同就可以了

在这里我们在A,B上加入参数,以实现奇偶插入

A:my.ini上加入参数

auto_increment_offset = 1
auto_increment_increment = 2
这样A的auto_increment字段产生的数值是:1, 3, 5, 7, …等奇数ID了

B:my.ini上加入参数

auto_increment_offset = 2
auto_increment_increment = 2
这样B的auto_increment字段产生的数值是:2, 4, 6, 8, …等偶数ID了

可以看出,你的auto_increment字段在不同的服务器之间绝对不会重复,所以Master-Master结构就没有任何问题了。当然,你还可以使用3台,4台,或者N台服务器,只要保证auto_increment_increment = N 再设置一下auto_increment_offset为适当的初始值就可以了,那样,我们的MySQL可以同时有几十台主服务器,而不会出现自增长ID重复。

在这里我们说的是2台MYSQL服务器,你也可以扩展到多台,实现方法类似
A -> B -> C-> D ->A
这样一个环形的备份结构就形成了,最后可要记住 自增长ID(主键)要设计好哦,否则会出错的。

上述内容就是mysql中怎么实现主主同步,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注行业资讯频道。

服务器 服务 同步 增长 不同 参数 字段 偶数 内容 奇数 技能 数值 文件 方法 知识 结构 问题 保证 登录 配置 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 企业物联网大数据平台软件开发 国家网络安全宣传周 宣讲 海南优鹿互联网有限科技公司 数据库中检查约束关键词 索尼 安卓 代理服务器设置 思科服务器管理控制器密码 小黄鸟下载服务器 考试软件开发费用是多少 徐州通用软件开发售后服务 数据库可以查出用户登录ip吗 mta软件开发工程师证书 软件开发就是app的研发吗 东营便民平台软件开发系统 软件开发方向的论文怎么写 创维电视无法解析服务器域名 南云畅网络技术有限公司 云南视频会议服务器厂家 五种常用数据库及特点 网络安全顾问具备那些 分布式数据库加工 k8s调用外部数据库 数据库查询指定用户命令 嘉兴生活缴费软件开发团队 数据库核废水 计算机网络技术1.7答案 标志着美国国家网络安全政策 C 提取数据库一个值 北京筑巢家宜网络技术 政务云计算中心网络安全 手机淘宝服务器出错
0