MySQL报错Lost connection to MySQL server at ‘reading initial communication packet’的解决办法

马谦马谦马谦 MySQL评论28,06811字数 549阅读1分49秒阅读模式

使用mysql连接远程服务器时报错,在百度和google查找都没有找到能解决问题的办法:

分析应该是以下两个原因导致的:

  1. 服务器有防火墙,禁止3306端口的访问。
  2. 用户没有授权远程访问。

第二个错误首先被排除掉了,根据多年的经验来看,如果是没有权限报错应该是Access Deny或者Permission相关的错误,但是这个错误从没见过。

因此排查的重心就放在了防火墙上了,首先在服务端查看防火墙,防火墙是关闭的状态,并且3306端口允许所有主机访问:

MySQL报错Lost connection to MySQL server at ‘reading initial communication packet’的解决办法-图片1

说明不是第一种场景导致的。那么问题来了,这到底是个什么奇葩错误?没办法,只能上终极大招了——抓包。

使用tcpdump抓包:

然后放到本地用wireshark打开,一个明显的错误就映在眼前了:

MySQL报错Lost connection to MySQL server at ‘reading initial communication packet’的解决办法-图片2

1130,没有权限访问,说明还是用户没有权限访问服务器导致:

MySQL报错Lost connection to MySQL server at ‘reading initial communication packet’的解决办法-图片3

气到吐血!不知道为什么没有权限客户端是这种鬼错误,直接打印服务端返回来的错误不就行了吗?wtf!

这是一台内网的虚拟机设备,root用户没有开外网访问权限,很久没有使用了不记得了。

解决办法

给root权限加上外网访问权限:

 
马谦马谦马谦
  • 本文由 马谦马谦马谦 发表于 2020年2月29日19:09:49
  • 转载请务必保留本文链接:https://www.dyxmq.cn/databases/mysql/lost-connection-to-mysql-server-at-reading-initial-communication-packet.html
MySQL中的B+树索引和哈希索引 MySQL

MySQL中的B+树索引和哈希索引

一、为什么要使用索引 索引是存储引擎用于快速找到记录的一种数据结构。索引对于数据库良好的性能十分关键,尤其是表中的数据量越来越大时,索引对性能的影响十分明显。 《高性能MySQL》中对索引的评价是:索...
数据库中的多版本并发控制(MVCC) MySQL

数据库中的多版本并发控制(MVCC)

一、概述 事务的出现给并发带来了巨大的便利性,它的ACID特性使得数据在并发时更加可靠。但是对于事务而言,它也会导致出现第一类丢失更新、第二类丢失更新、脏读、不可重复读以及幻读的问题,当然又出现了多种...
MySQL中的行锁、两阶段锁协议以及死锁 MySQL

MySQL中的行锁、两阶段锁协议以及死锁

一、行锁和两阶段锁协议 行锁:顾名思义,就是对某一行加锁,修改的时候不会锁住整个表。相对于表锁来说,行锁的开销更大(因为涉及到MVCC等需要保存快照),但是粒度更小,更适合于高并发场景。行锁是每个引擎...
匿名

发表评论

匿名网友
:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:
确定

拖动滑块以完成验证