我的编程空间,编程开发者的网络收藏夹
学习永远不晚

实现互为双主搭建MySQL数据库方法

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

实现互为双主搭建MySQL数据库方法

本文主要给大家简单讲讲实现互为双主搭建MySQL数据库方法,相关专业术语大家可以上网查查或者找一些相关书籍补充一下,这里就不涉猎了,我们就直奔主题吧,希望实现互为双主搭建MySQL数据库方法这篇文章可以给大家带来一些实际帮助。

1.双主实现方案:

1、让表的id 自增,然后主一写1,3,5,,,,,主2写2,,4,6,,,,

2、不让表的id 自增,然后通过web程序去seq云服务器读取id ,写入双主。

双主工作场景:高鬓发写的场景,慎用。

和多实例及主从同步对比:主主数据库多增加的参数:

2.第一个方法实现主主复制:

1、主从同步【主库】M需要增加的参数:

auto_increment_increment        = 2

auto_increment_offset           = 1

log-slave-updates

log-bin = /data/3306/mysql-bin

expire_logs_days = 7

/etc/init.d/mysqldrestart

2、主从同步【从库】S需要增加的参数:

auto_increment_increment        = 2

auto_increment_offset           = 2

log-bin = /data/3307/mysql-bin

log-slave-updates

expire_logs_days = 7

/etc/init.d/mysqld restart

3.参数配置生效验证:

mysql -uroot -p123456 -e "showvariables like 'log_%';"|grep -i "on"

mysql -uroot -p123456 -e "showvariables like 'log_%';"|grep -i "on"

mysql -uroot -p123456 -e "showvariables like 'auto%';"|egrep "2|1|2"

mysql -uroot -p123456 -e "showvariables like 'auto%';"|egrep "2|1|2"

4.对从库mysql-5.6.16-slave1备份:

mysqldump -uroot -p123456 -B -A -F -R -x--master-data=1  --events|gzip>/backup/slave_$(date +%F).sql.gz

scp -rp -P22/backup/slave_2016-08-19.sql.gz root@172.16.1.41:/backup

5.主库导入由从库推送过来的数据:

gzip -d /backup/slave_2016-08-19.sql.gz

mysql -uroot -p123456</backup/slave_2016-08-19.sql

6.在主库执行change master to

mysql -uroot -p123456 -e "CHANGEMASTER TO  MASTER_HOST='172.16.1.42',MASTER_PORT=3306,MASTER_USER='rep',MASTER_PASSWORD='111111';startslave;”

[root@mysql-5 data]# mysql -uroot-p123456 -e "show slave status\G"|grep -i yes

Warning: Using a password on the commandline interface can be insecure.

            Slave_IO_Running: Yes

            Slave_SQL_Running: Yes

172.16.1.42这个ip地址为从库MySQL-5.6.16-slave1的ip地址

到此处实现双主

7.演示:

Master1端插入数据演示:

Master1:172.16.1.41

mysql -uroot -p123456 -e "create databasewjw05"

mysql> use wjw01;

mysql> CREATE table `t1` (`id` bigint(12) NOTNULL auto_increment,`name` varchar(12) NOT NULL,PRIMARY KEY (`id`) );

mysql> INSERT INTO t1(name) values('wangwu');

slave2:172.16.1.43

[root@mysql-5 backup]# mysql -uroot-p123456 -e "select * from wjw01.t1"

Warning: Using a password on the commandline interface can be insecure.

+----+---------+

| id | name    |

+----+---------+

| 1 | wangwu  |

在从库slave2查看 ,数据已经同步过来了

Master2___slave1:172.16.1.42

mysql -uroot -p123456 -e "select *from wjw01.t1"

主库master1 的数据没有同步到主库master2__slave1

Master2__slave1端插入数据演示:

mysql> use wjw01;

mysql> INSERT INTO t1(name) values('oldgirl');

slave2:172.16.1.43查看:

[root@mysql-5 backup]# mysql -uroot -p123456 -e"select * from wjw01.t1"

Warning: Using a password on the command lineinterface can be insecure.

+----+---------+

| id | name   |

+----+---------+

|  1 | wangwu  |

|  2 |oldgirl |

数据同步过去了

Master1:172.16.1.41查看:

[root@mysql-5 data]# mysql -uroot -p123456-e "select * from wjw01.t1"

Warning: Using a password on the commandline interface can be insecure.

+----+---------+

| id | name    |

+----+---------+

|  1| wangwu  |

Master2_slave1端的数据库没有同步到master1端

在master2__slave1端和master1端查看:同步过程中并没有报错,太奇怪了

[root@mysql-5 binlog]#  mysql -uroot -p123456 -e "show slavestatus\G"|grep -i "yes"

Warning: Using a password on the commandline interface can be insecure.

            Slave_IO_Running: Yes

           Slave_SQL_Running: Yes

[root@mysql-5 data]#   mysql -uroot -p123456 -e "show slavestatus\G"|grep -i "yes"

Warning: Using a password on the commandline interface can be insecure.

             Slave_IO_Running: Yes

            Slave_SQL_Running: Yes

在网上查找找到问题的原因了:

解决办法:(网友提供)

statement模式不足以应付应用,换成mixed试试看吧:

在master2__slave1端操作:

mysql> STOP SLAVE;

Query OK, 0 rows affected (0.02 sec)

mysql> SET GLOBAL binlog_format=MIXED;

Query OK, 0 rows affected (0.00 sec)

mysql> START SLAVE;

Query OK, 0 rows affected (0.00 sec)

mysql> show slave status\G

问题解决。提示:此处修改只是临时生效,一旦重启MySQL服务,就会失效,把参数加在my.cnf配置文件从启MySQL服务,永久生效,

Master2__slave1端的参数正确的设置方法:

[root@mysql-5 binlog]# cat -n /etc/my.cnf |sed -n'42,49p'

    42     ###双主实现方法###

    43     log_bin = /home/mysql/data/binlog/mysql-bin

    44     auto_increment_increment        = 2

    45     auto_increment_offset           = 2

    46     log-slave-updates

    47     expire_logs_days = 7

    48     binlog_format = mixed

    49     ###双主实现方法###

在master1端继续插入数据

mysql>  INSERT INTO t1(name) values('pig');

slave2段查看:

[root@mysql-5 binlog]#  mysql -uroot -p123456 -e "select * fromwjw01.t1"

Warning: Using a password on the command lineinterface can be insecure.

+----+---------+

| id | name   |

+----+---------+

|  1 | wangwu  |

|  2 |oldgirl |

|  3 |pig     |

Master2__slave1端查看:

[root@mysql-5 backup]# mysql -uroot -p123456 -e"select * from wjw01.t1"

Warning: Using a password on the command lineinterface can be insecure.

+----+---------+

| id | name   |

+----+---------+

|  1 | wangwu  |

|  2 |oldgirl |

|  3 |pig     |

Master2__slave1端插入数据:

mysql>  INSERT INTO t1(name) values('apple');

在master1段查看:数据同步过去了

[root@mysql-5 data]# mysql -uroot -p123456 -e"select * from wjw01.t1"

Warning: Using a password on the command lineinterface can be insecure.

+----+---------+

| id | name   |

+----+---------+

|  1 | wangwu  |

|  2 |oldgirl |

|  3 |pig     |

|  4 |apple   |

在slave2段查看:数据同步过去了

[root@mysql-5 data]# mysql -uroot -p123456 -e"select * from wjw01.t1"

Warning: Using a password on the command lineinterface can be insecure.

+----+---------+

| id | name   |

+----+---------+

|  1 | wangwu  |

|  2 | oldgirl|

|  3 |pig     |

|  4 |apple   |

实现互为双主搭建MySQL数据库方法就先给大家讲到这里,对于其它相关问题大家想要了解的可以持续关注我们的行业资讯。我们的板块内容每天都会捕捉一些行业新闻及专业知识分享给大家的。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

实现互为双主搭建MySQL数据库方法

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

下载Word文档

猜你喜欢

docker-compose启动mysql双机热备互为主从的方法实现

目录1. 环境说明2. 启动 mysql-013. 启动 mysql-024. 配置主从同步4.1 mysql-01(master) ==> mysql-02(slave)4.2 mysql-02(master) ==> mysql-01(
2022-07-14

使用Docker搭建MySQL主从数据库的方法步骤

目录1. 准备主服务器2. 准备从服务器3. 启动主从同步4. 实现主从同步5. 停止和重置很多人对主从数据库有一个误区,把多个mysql搭建在同一个服务器上,性能提升是不是很有限?这个理念是错误的,数据库的性能瓶颈主要是在IO和CPU负载
2023-01-11

如何为 MySQL 数据库实现双向 SSL 认证

如何为 MySQL 数据库实现双向 SSL 认证什么是双向 SSL 认证?双向 SSL(Secure Sockets Layer)认证是一种加密通信方式,它要求服务端和客户端之间互相验证对方的身份。在数据库中,双向 SSL 认证可确保只有经
2023-10-22

在阿里云搭建 MySQL 数据库的方法

简介在阿里云上搭建MySQL数据库是一项常见的任务,它可以帮助您轻松地管理和存储数据。本文将介绍如何在阿里云上搭建MySQL数据库,并提供一些实用的技巧和建议。步骤一:购买阿里云服务器首先,您需要在阿里云上购买一台云服务器。选择适合您需求的服务器类型和配置,并确保其具有足够的计算能力和存储空间。步骤二:安装MySQL数
在阿里云搭建 MySQL 数据库的方法
2024-01-30

shell脚本实现mysql数据库双机定时备份的方法

目录1 缘起与目的2 确认环境2.1 导出数据库sql脚本2.2 跨机器拷贝2.3 docker容器确认环境3 构建脚本3.1 脚本内容3.2 手动执行脚本确认正常4 定时任务1 缘起与目的最近有个需求,要求实现对某个数据库进行双机备份,
2022-07-20

k8s搭建mysql集群实现主从复制的方法步骤

目录环境介绍一、部署NFS服务器二、创建PV三、编写mysql的yaml文件四、启动MySQL五、验证MySQL主从复制环境介绍名称版本操作系统IP备注K8S集群1.20.15Centos7.9192.168.11.21 192.168.
2023-01-05

MYSQL数据库GTID实现主从复制实现(超级方便)

一、添加Maria源vi /etc/yum.repos.d/MariaDB.repo粘贴阿里云的最新mariadb镜像:[mariadb] name = MariaDB baseurl = https://mirrors.aliyun.co
2022-05-12

编程热搜

目录