mysql5.7.19版本的主从复制问题分享
admin
2023-05-15 21:02:17
0

今天学习构建mysql 5.7.19版本的MySQL的主从复制

碰到了一些坑,特定分享下:

  1. mysql的主从服务器是通过克隆虚拟机完成,导致uuids一样,需要修改auto.cnf文件

  2. 在slave上想通过在/etc/my.cnf里添加连接master的配置,总是导致启动mysqld服务失败,看错误日志,说不支持的选项。原因是5.7.19里已经淘汰了在配置文件里加这种配置的方法了。


下面是部分笔记,特分享下。

mysql> show variables like "%binlog%";

| binlog_format                           | ROW  

====

如何让程序能同时读取主和从服务器上的数据:

1.直接在程序里写死,那个业务访问那台MySQL服务器ip,定死。 ---》很傻、维护起来非常麻烦,需要开发的协助。

不同的业务,不同的服务器

a ----》MYSQL(A)

B ---->MYSQL(B)

2.相同的业务,不同的服务器。使用域名解析来达到读写分离。 ---》比较简单,只要修改下域名对应的ip

写 ----》主

wdb.abc.com  --->132.1.1.5  主

读 -----》主、从    

可以使用负载均衡域名解析

rdb.abc.com  --->132.1.1.1

rdb.abc.com  --->132.1.1.2

rdb.abc.com  --->132.1.1.3

rdb.abc.com  --->132.1.1.4  从

rdb.abc.com  --->132.1.1.5  主

3.使用中间件来实现读写分离。oneproxy---》杭州平民软件---》王广友

中间件里有个配置文件,会写明读往那些服务器,写往那台服务器。

开源:mycat



=====

主从复制-----》为读写分离做铺垫。---》提升性能的作用。

=====

MySQL  replication  复制

   master   slave

   write  read


=====

克隆 clone

1.先关闭计算机


=====

主从复制的前提条件:

2台MySQL服务器的数据是一样的。

=====

将master和slave的ip地址配置好,不要一样,同时修改主机名为mysql_master  、mysql_slave


mysql> grant replication slave  on *.* to 'backup'@'192.168.0.139' identified by '123456';

mysql> CREATE USER 'repl'@'%.mydomain.com' IDENTIFIED BY 'slavepass';

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

====

/etc/my.cnf


server-id=2

log-bin

master-host=192.168.0.137

master-user=backup

master-password=123456

master-port=3306

目前不可行,总是报错

mysql 官方给的解释:

Obsolete Replication Slave Options  废弃的主从复制的选项

The following options are removed in MySQL 5.5. If you attempt to start mysqld with any of these

options in MySQL 5.5, the server aborts with an unknown variable error. To set the replication

parameters formerly associated with these options, you must use the CHANGE MASTER TO ...

statement (see Section 13.4.2.1, “CHANGE MASTER TO Syntax”).

The options affected are shown in this list:

? --master-host

? --master-user

? --master-password

? --master-port

? --master-connect-retry


? --master-ssl

? --master-ssl-ca

? --master-ssl-capath

? --master-ssl-cert

? --master-ssl-cipher

? --master-ssl-key


===

在从服务器的数据库里输入命令:

mysql> change master to master_host='192.168.0.137', master_user='backup', master_password='123456', master_port=3306;


mysql> START SLAVE;

Query OK, 0 rows affected (0.00 sec)


mysql>

             Slave_IO_Running: No   IO线程启动不起来

            Slave_SQL_Running: Yes

出错信息:

                Last_IO_Error: Fatal error: The slave I/O thread stops because master and slave have equal MySQL server UUIDs; these UUIDs must be different for replication to work

  原因是MySQL的server UUID一样

[root@mysql-slave mysql]# pwd

/var/lib/mysql      ---》存放在此目录下

[root@mysql-slave mysql]# 

[root@mysql-slave mysql]# vim auto.cnf   修改此文件里的uuid

[auto]

server-uuid=7fce030c-9f7b-11e7-b09f-000c29e2a2e4

[root@mysql-slave mysql]# service mysqld restart

Redirecting to /bin/systemctl restart  mysqld.service

[root@mysql-slave mysql]# 

             Slave_IO_Running: Yes

            Slave_SQL_Running: Yes

====

不要在slave里写数据,会导致SQL thread线程不工作,如果已经写了,建议删除,重新启动下slave 进程

mysql> start slave;

===

relay-log.info ---》记录上次从主服务器的binlog日志里什么位置,下次去复制下载主的binlog日志的时候,知道从哪里开始。

master.info  --->连接主服务器使用的(主的ip和连接使用的用户和密码)

mysql-slave-relay-bin.000006  记录中继日志被重新执行的时候的二进制日志

====

1.主从服务器之间复制数据的时候,有延迟吗?是否有数据丢失的现象发生?

主从服务器存放在一个机房好,还是2个机房好?

2.如何减少延迟?如何避免数据丢失?

3.半同步复制是什么?

4.主服务器down机了,从服务器如何顶替主服务器工作?

5.主服务器又恢复了,又可以充当什么角色?主还是从?

6.了解mycat和oneproxy中间件程序,实现读写分离

===

联系方式:695811769@qq.com

相关内容

热门资讯

网传“三大运营商即将免月租”,... 最近,大家在各大社交平台都可能刷到过这样一条消息——三大运营商即将全面推出免月租、按量计费套餐。有不...
今年20岁的老剧,多少年轻人还... “20年快得很,弹指一挥间。”20年来,相关讨论和衍生创作不断,甚至还有一批批新生代观众陆续“搬进”...
总书记引领强国之路|聚天下英才... 原标题:学习新语·总书记引领强国之路|聚天下英才而用之
燃气灶开大火嘀一声熄灭怎么回事 可能是因为电池没电了,解决方法就是换掉燃气灶的电池,然后检查出现故障的那头,观察中间的火焰是否可以燃...
冰箱冷冻风扇异响怎么办 原因可能是冰箱的弹力垫圈存在相应的损坏,要进行弹力垫圈的更换也可以降低冰箱的工作噪音;原因可能是风扇...
美的空调发出哒哒哒的异响是怎么... 以美的空调为例,空调发出哒哒哒的异响的原因大致有四种,具体原因及解决方法如下所示: 1、有可能是因...
油烟机电机异响无力的原因 油烟机是厨房中的必备家电之一,其主要功能是抽取烹饪过程中的烟雾和油蒸气。油烟机电机是其重要组成部分,...
冰箱冷藏的风扇异响怎么办 原因可能是冰箱风扇处有异物,可以通过清除异物的方法来解决。原因可能是冰箱风扇风机润滑不良,可以通过添...
特朗普松口:可接受伊朗暂停核计... 据凤凰卫视报道,结束访华行程的美国总统特朗普,5月15日在空军一号上,被问到是否已拒绝伊朗提出的最新...
德国总理,你这句话够狠 不得不说,德国总理默茨这句话,够狠够生猛。曾几何时,美欧是亲密的一家,很多西方国家孩子以去美国读书生...