记一次bug排查(.exe链接mysql失败)-每天学习一点点

哎! 从来没有接手过的项目, .exe项目, 链接服务器失败 报错:"unable to connect to any of the specified mySQL hosts"

虽然不懂c++的代码, 也没法反编译.exe项目, 还是像挑战尝试一下解决这个问题.

明面看就是链接mysql失败. 但是mysql对应的服务器地址是啥呢?

方案1: 检查自己常用的mysql服务器是否异常

用自己的navicat等软件, 链接一下自己的测试库,压测库,线上从库,等各种自己能链接的数据库, 快速定位看看哪个服务器宕机了.

哎! 查找失败,估计是一个我从来没有链接过的数据库.

方案2: 查找配置文件

给了一个.exe 对应的文件夹目录里面还有很多其它的文件, 我来看看有没有mysql相关链接的.

哎! 查找失败, 估计是.exe文件里面写死的不是从外部配置文件中引入的.解包太费事,搁置一下.

方案3: 使用 Process Monitor 监控连接请求

还有这么好用的工具, 之前怎么不知道.

开启监控, 过滤我的项目名称, 哎! 咋还没有TCP链接呢?

哎! 查找失败, 不明原因导致监控连接不能正常监控到我的这个项目的TCP链接.

方案4: 使用python+netstat扫描

python 复制代码
import os
while True:
    os.system("netstat -ano | findstr 3306") 

运行起来了, 一看, 哇好多链接啊! 我来甄别一下哪个是我需要的。 咦! 怎么这么多熟悉的, 这个是测试,这个是压测, 这个是线上从库。嗷呜! 我的navicat忘了关了, 麻蛋。

关了之后, 额, 一个3306的端口也没有了。

哎!查找失败, 应该是我的端口盲猜3306的不准确。继续盲猜更多端口性价比低,暂且搁置。

方案5: 使用 Wireshark 抓包分析

专业的事交给专业的"软件"来干。下载安装,无脑下一步,啊! 咋我的电脑在重启, 我的文档还都没有保存呢!我日。。。哎! 心疼自己三分钟。 (吸取教训,安装软件最后一定要看看是否重启电脑)

电脑重启了,关闭自动启动起来的软件,减少其它软件影响,方便分析问题。

好开启我的监听软件。开启我的异常.exe软件。

按照Protocol排序,TCP一共这么几个, 纯黑纯黑的里面我看到了一个端口3307, 3306的孪生兄弟.估计是服务器端口3306被其它mysql占用了,所以用的3307,

ps:端口有了,服务器ip有了,发给运维的小伙伴, 重启一下服务。验证ok,收工回家。

问了一下运维为啥关停,原来是之前中病毒了, 安全组给禁了。

相关推荐
IT二叔17 小时前
Git Flow04-bug修改流程
git·bug
万粉变现经纪人2 天前
如何解决 pip install shapely 报错 GEOS C 库未找到 问题
c语言·开发语言·python·pycharm·bug·pandas·pip
cyforkk2 天前
前后端联调实战:解决业务异常被误判为成功的“幽灵 Bug”
bug·状态模式
li9056632802 天前
hanzi-writer-miniprogram Path2D问题以及Bug修复
微信小程序·bug
万粉变现经纪人3 天前
如何解决 pip install cx_Oracle 报错 未找到 Oracle Instant Client 问题
数据库·python·mysql·oracle·pycharm·bug·pip
ChoSeitaku4 天前
Git分支|创建分支|切换分支|合并分支|删除分支|合并冲突分支|分支策略|bug分支|强制删除分支
bug
Lxinccode5 天前
BUG(23) : node版claude code启动报错Failed to connect to api.anthropic.com: ETIMEDOUT
bug·claude·claude启动报错
buyulian5 天前
Bug防御体系:技术方案的优与劣
java·经验分享·bug·软件工程
川石课堂软件测试6 天前
接口测试需要注意的一些BUG
网络·数据库·python·单元测试·bug·压力测试·tornado
深念Y6 天前
记一个BUG:Trae里MongoDB和MySQL MCP不能共存
数据库·mysql·mongodb·ai·bug·agent·mcp