暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

故障分析 | MySQL:我的从库竟是我自己!?

168

作者:秦福朗

爱可生 DBA 团队成员,负责项目日常问题处理及公司平台问题排查。热爱互联网,会摄影、懂厨艺,不会厨艺的 DBA 不是好司机,didi~

本文来源:原创投稿

* 爱可生开源社区出品,原创内容未经授权不得随意使用,转载请联系小编并注明来源。



1背景

有人反馈装了一个数据库,来做现有库的从库。做好主从复制关系后,在现有主库上使用 show slave hosts;
管理命令去查询从库的信息时,发现从库的 IP 地址竟是自己的 IP 地址,这是为什么呢?

因生产环境涉及 IP,端口等保密信息,以下以本地环境来还原现象。

2本地复现

基本信息


主库从库
IP10.186.65.3310.186.65.34
端口66076607
版本8.0.188.0.18

问题现象

不多说,先上图,以下为在主库执行 show slave hosts;
出现的现象:

可以看到这里的 Host 是主库的 IP 地址。

我们登陆从库查看一下 show slave status\G

mysql> show slave status\G
*************************** 1. row ***************************
               Slave_IO_State: Waiting for master to send event
                  Master_Host: 10.186.65.33
                  Master_User: universe_op
                  Master_Port: 6607
                Connect_Retry: 60
              Master_Log_File: mysql-bin.000002
          Read_Master_Log_Pos: 74251749
               Relay_Log_File: mysql-relay.000008
                Relay_Log_Pos: 495303
        Relay_Master_Log_File: mysql-bin.000002
             Slave_IO_Running: Yes
            Slave_SQL_Running: Yes

我们看到确实从库是在正常运行的,且复制的源就是主库。

为什么执行 show
命令看到的 Host 和实际的情况对不上呢?

3查阅资料

首先查阅官方文档,关于 show slave hosts;
语句的解释:

  • 首先说明 8.0.22 之后版本的 show slave hosts
    语句被废弃(可执行),改为 show replicas
    ,具体机制还是一样的。
  • 这里说明了各个数据的来源,多数来源于 report-xxxx
    相关参数,其中 Host 的数据来自于从库的 report_host
    这个参数。

然后,我们测试在从库执行 show variables like "%report%";

mysql> show variables like "%report%";
+-----------------+--------------+
| Variable_name   | Value        |
+-----------------+--------------+
| report_host     | 10.186.65.33 |
| report_password |              |
| report_port     | 6607         |
| report_user     |              |
+-----------------+--------------+
4 rows in set (0.01 sec)

可以看到这里显示的就是主库的 IP。

我们再查询 report_host
的参数基本信息:

可以看到该参数非动态配置,在从库注册时上报给主库,所以主库上执行 show slave hosts;
看到的是 IP 是从这里来的,且无法在线修改。

最后也通过查看从库上的 my.cnf
上的 report_port
参数,证实确实是主库的 IP:

4结论

经了解,生产上的从库是复制了主库的配置文件来部署的,部署时没有修改 report_host
这个值,导致启动建立复制后将 report_host
这个 IP 传递给主库,然后主库查询 show slave hosts
时就出现了自己的 IP,让主库怀疑自己的从库竟然是自己。

生产上大部分人知道复制主库的配置文件建立新库要修改 server_id
等相关 ID 信息,但比较容易忽略掉 report_ip
report_port
等参数的修改,这个需要引起注意,虽然错误之后看起来对复制运行是没影响的。



本文关键字:#MySQL# #复制#

活动推荐:
【深圳 7.15】ActionDB 与您相约 OB Cloud 公开课开放麦环节



【北京 7.21】爱可生邀您参加 Gdevops 全球敏捷运维峰会 北京站




文章推荐:

技术分享 | OceanBase 慢查询排查思路

技术分享 | OceanBase写入限速源码解读

故障分析 | innodb_thread_concurrency 导致数据库异常的问题分析

故障分析 | OceanBase 频繁更新数据后读性能下降的排查

故障分析 | MySQL 升级到 8.0 变慢问题分析

技术分享 | 一招解决 MySQL 中 DDL 被阻塞的问题

故障分析 | 一条本该记录到慢日志的 SQL 是如何被漏掉的



关于 SQLE

爱可生开源社区的 SQLE 是一款面向数据库使用者和管理者,支持多场景审核,支持标准化上线流程,原生支持 MySQL 审核且数据库类型可扩展的 SQL 审核工具。

SQLE 获取

类型地址
版本库https://github.com/actiontech/sqle
文档https://actiontech.github.io/sqle-docs/
发布信息https://github.com/actiontech/sqle/releases
数据审核插件开发文档https://actiontech.github.io/sqle-docs-cn/3.modules/3.7_auditplugin/auditplugin_development.html
提交有效 pr,高质量 issue,将获赠面值 200-500 元(具体面额依据质量而定)京东卡以及爱可生开源社区精美周边!
更多关于 SQLE 的信息和交流,请加入官方QQ交流群:637150065

文章转载自爱可生开源社区,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论