【Mysql】基于MySQL协议的抓包工具

mysql_sniffer 是一个基于 MySQL 协议的抓包工具,用来实时抓取 MySQL 服务端的请求,并格式化输出,输出内容包括访问时间、来源 IP、执行的SQL语句。

在进行MySQL 8.0升级时,了解新版本对SQL语法的改变和新增的功能是非常重要的。通过使用mysql_sniffer,DBA可以在升级之前对现有的SQL语句进行抓取和分析,以确保在新版本中能够正常运行。

使用mysql_sniffer工具可以带来以下几点好处:

  • **对SQL语法的改变有更深入的了解:**MySQL 8.0引入了一些新的SQL语法,也对一些旧的语法进行了修改或弃用。通过mysql_sniffer,DBA可以抓取并分析现有的SQL语句,以确定它们是否会受到这些改变的影响。

  • **发现并解决潜在的问题:**如果在新版本中,某些SQL语句无法正常运行,那么通过mysql_sniffer,DBA可以提前发现这些问题,并在升级之前进行修复。

有一些已知SQL语法与MySQL 8.0不兼容,例如:

复制代码
select NVL(id/0,'YES') from test.t1 where id = 1;select user_id,sum(amount) from test.user group by user_id DESC limit 10;

第一条语句,NVL函数是MariaDB特有的,在MySQL 8.0中,要改成:

复制代码
select IFNULL(id/0,'YES') from test.t1 where id = 1;

第二条语句,在MySQL 8.0中group by 字段 ASC/DESC 失效,要改成:

复制代码
select user_id,sum(amount) from test.user group by user_id order by user_id DESC limit 10;

那么,如何判断业务上的未知SQL是否与MySQL 8.0兼容呢?

mysql_sniffer工具可以帮助你

**介绍:**​​​​​​​

复制代码
usage: mysql_sniffer [-h] -p PORT [-t TABLES [TABLES ...]] [-l LOG] [-c] [-r RUNTIME] [-v]
MySQL packet sniffer
options:  -h, --help            show this help message and exit  -p PORT, --port PORT  MySQL server port  -t TABLES [TABLES ...], --tables TABLES [TABLES ...]                        Table names to capture  -l LOG, --log LOG     Log file path  -c, --console         Print log to console  -r RUNTIME, --runtime RUNTIME                        Runtime of packet sniffing in seconds  -v, --version         show program's version number and exit

参数解释:

-p 指定端口,MySQL默认3306

复制代码
-c 是把抓取到的SQL打印到终端
-t 指定具体的表名,例如只抓取t1,t2,t3这三张表, -t t1 t2 t3 (不支持正则表达式,请写具体的表名)
-l 抓取的SQL保存在哪个文件里,不指定默认保存在mysql_packet.sql文件里
-r 抓取多长时间,单位秒

使用:

复制代码
shell> ./mysql_sniffer -p 3306

将会抓取60秒数据(-r 代表抓取的时间,单位秒),默认会把线上的SQL语句(select/insert/update/delete)存入mysql_packet.sql文件里。

抓取1-10分钟数据,然后把mysql_packet.sql文件拷贝到MySQL 8.0测试环境里,然后执行下面的命令:

复制代码
mysql -S /tmp/mysql_mysql8_1.sock yourDB < mysql_packet.sql > /dev/null

看报错信息。没有报错,就代表SQL是兼容的。

注:请确保生产环境和测试环境的表结构一致,测试环境不需要任何数据。

相关推荐
曹牧14 分钟前
Oracle:UNIX时间戳
数据库·oracle·unix
XiaoLin laile19 分钟前
【无标题】
网络·数据库·人工智能
朝阳58132 分钟前
MySQL 主从复制 — Docker 双机灾备方案
数据库·mysql·docker
染翰33 分钟前
生产级 MySQL 内存占用过高排查指南
数据库·mysql
一 乐44 分钟前
网上订餐系统|基于springboot的网上订餐系统设计与实现(源码+数据库+文档)
java·数据库·spring boot·后端·论文·毕设·网上订餐系统
guslegend1 小时前
第3节:智能体配置表设计
数据库·人工智能
jiayong231 小时前
MySQL 排序规则冲突问题与 utf8mb4_general_ci 统一方案
android·mysql·ci/cd
雷工笔记1 小时前
SQL系列2:PostgreSQL 日期时间字段类型选择指南
数据库·sql·postgresql
SAP上海工博云署1 小时前
2026年中小企业SAP服务商选型技术解析
大数据·运维·数据库·人工智能·信息可视化·运维开发·信息与通信
RestCloud1 小时前
版本迭代丨谷云科技ETLCloud V4.2版本更新速览
数据库·doris·etl·etlcloud·数据集成平台·datahub·ftp处理