中午刚想趴一会,不料锅从天降!!!Mysql连不上了。。。。。。。

现象如下:

现象1:登录mysql所在服务器,连接MySQL 成功;

现象2:通过客户端远程连接MySQL,返回失败,如下:

Enter password:
ERROR 2003 (HY000): Can't connect to MySQL server on 'xxx' (111)

现象三:通过某些客户端可以连,就是响应极慢。

现象四:通过客户端可以ping通,但是telnet 数据库端口失败。且无论ping还是telnet,数据库服务器均收不到数据包。

客户端: tcpdump -nn -i eth0 icmp  和  执行ping 服务端ip的操作
服务端: tcpdump -i br0 -nn icmp and host 客户端ip

现象五:show processlist 有好多unauthenticated user的用户(参考参考连接所述)

mysql> show processlist;
+-----+----------------------+---------------------+---------------------+---------+------+-------+------------------+
| Id | User | Host | db | Command | Time | State | Info |
+-----+----------------------+---------------------+---------------------+---------+------+-------+------------------+
| 2 | root | 192.168.1.60:43961 | xxx | Sleep | 39 | | NULL |
| 7 | root | 192.168.1.34:41155 | xxx | Sleep | 7 | | NULL |
| 30 | root | 192.168.20.7:38282 | xxx | Sleep | 6 | | NULL |
| 44 | root | 192.168.20.7:38308 | xxx | Sleep | 6 | | NULL |
| 106 | root | 10.88.9.23:61181 | NULL | Sleep | 19 | | NULL |
| 110 | unauthenticated user | 10.88.128.22:38648 | NULL | Connect | NULL | login | NULL |
| 111 | unauthenticated user | 10.88.10.185:57430 | NULL | Connect | NULL | login | NULL |
| 112 | unauthenticated user | 10.88.11.196:56473 | NULL | Connect | NULL | login | NULL |
| 113 | unauthenticated user | 10.88.128.22:38650 | NULL | Connect | NULL | login | NULL |
| 114 | unauthenticated user | 10.88.10.185:57439 | NULL | Connect | NULL | login | NULL |
| 115 | unauthenticated user | 10.88.128.117:58555 | NULL | Connect | NULL | login | NULL |
| 116 | unauthenticated user | 10.88.128.22:38653 | NULL | Connect | NULL | login | NULL |
| 117 | unauthenticated user | 10.88.10.185:57444 | NULL | Connect | NULL | login | NULL |
| 118 | unauthenticated user | 10.88.128.22:38655 | NULL | Connect | NULL | login | NULL |
| 119 | unauthenticated user | 10.88.128.22:38657 | NULL | Connect | NULL | login | NULL |
| 120 | unauthenticated user | 10.88.10.185:57453 | NULL | Connect | NULL | login | NULL |
| 122 | unauthenticated user | 10.88.128.22:38659 | NULL | Connect | NULL | login | NULL |
| 123 | unauthenticated user | 10.88.128.22:38661 | NULL | Connect | NULL | login | NULL |
| 124 | unauthenticated user | 10.88.10.185:57458 | NULL | Connect | NULL | login | NULL |
| 125 | unauthenticated user | 192.168.20.45:47091 | NULL | Connect | NULL | login | NULL |
| 126 | unauthenticated user | 192.168.20.45:47092 | NULL | Connect | NULL | login | NULL |
| 127 | unauthenticated user | 192.168.20.45:47093 | NULL | Connect | NULL | login | NULL |
| 128 | root | localhost | NULL | Query | 0 | NULL | show processlist |
| 129 | unauthenticated user | 10.88.128.22:38664 | NULL | Connect | NULL | login | NULL |
+-----+----------------------+---------------------+---------------------+---------+------+-------+------------------+
24 rows in set (0.01 sec)

问题解决办法:

第一步:修改mysql的my.conf配置文件,在[mysqld]模块下增加,停止mysql的域名反向解析。之后重启数据库,此项解决大多数问题

skip-name-resolve

第二步: 重启客户端的网卡,再次连接mysql,搞定剩下的一小部分问题。

#service network restart
Shutting down interface eth0: [ OK ]
Shutting down loopback interface: [ OK ]
Bringing up loopback interface: [ OK ]
Bringing up interface eth0: Determining if ip address 10.88.128.66 is already in use for device eth0...
[ OK ]

结论

1.  针对MySQL的对连接的客户端进行DNS反向解析的处理,暂不晓得本质原因。网上暂没有搜到本质信息。参考【参考连接】

2. 网卡的问题,网管怀疑客户端的网卡自娱自乐了。。。。ping的时候压根没有走到目的地就返回了

【参考连接】:https://segmentfault.com/a/1190000002682272

今天早上开发那边发现mysql连接很慢,登陆到服务器上查看服务器日志都是正常的,无可疑记录,刚刚还好好的,怎么突然出现这个问题,于是登陆到mysql服务器上,查看下进程,发现有很多这样的连接:
| unauthenticated user | 192.168.10.6: | NULL | Connect | NULL | login | NULL
| unauthenticated user | 192.168.10.6: | NULL | Connect | NULL | login | NULL
........
放狗,放狗。。。
原因是由于mysql对连接的客户端进行DNS反向解析。
有2种解决办法:
,把client的ip写在mysql服务器的/etc/hosts文件里,随便给个名字就可以了。
,在 my.cnf 中加入 –skip-name-resolve 。
对于第一种方法比较笨,也不实用,那么 skip-name-resolve 选项可以禁用dns解析,但是,这样不能在mysql的授权表中使用主机名了,只能使用IP。
我理解mysql是这样来处理客户端解析过程的,
,当mysql的client连过来的时候,服务器会主动去查client的域名。
,首先查找 /etc/hosts 文件,搜索域名和IP的对应关系。
,如果hosts文件没有,则查找DNS设置,如果没有设置DNS服务器,会立刻返回失败,就相当于mysql设置了skip-name-resolve参数,如果设置了DNS服务器,就进行反向解析,直到timeout。
有一点不明白,为什么连接mysql服务器内网的ip地址也要进行DNS反向解析,而这时候DNS解析返回给mysql的是什么呢?
望高手解答。

如有错误,还请各位数据库大神不吝赐教。

谢谢

Mysql异常问题排查与处理——mysql的DNS反向解析和客户端网卡重启的更多相关文章

  1. SELinux导致PHP连接MySQL异常Can't connect to MySQL server的解决方法

    原文摘自:http://www.jb51.net/article/52581.htm 这篇文章主要介绍了SELinux导致PHP连接MySQL异常Can't connect to MySQL serv ...

  2. Linux - mysql 异常:登录不上mysql数据库

    问题描述 重启虚拟机之后,用命令 mysql -u root -p 登录不上 mysql 数据库,页面显示: 但是,用命令 service mysqld status 可以查看状态 解决方案 1.查看 ...

  3. MySQL异常:Caused by: com.mysql.jdbc.exceptions.MySQLTimeoutException: Statement cancelled due to timeout or client request

    Caused by: com.mysql.jdbc.exceptions.MySQLTimeoutException: Statement cancelled due to timeout or cl ...

  4. SELinux导致无法访问外网,PHP连接MySQL异常Can't connect to MySQL server、redis程序访问提示Redis server went away的解决方法

    今天上班遇到的问题,新配的Linux服务器,php.Apache和一系列扩展插件装好后,在本地好好的程序移上去就一直抱数据库连接错误,而用sql命令却能连接上去, 做了一个简单的判断数据库连接页面还是 ...

  5. 问题MySQL Error (2013): Lost connection to MySQL server at waiting for initial communication packet

    错误说明: SQL Error (2013): Lost connection to MySQL server at 'waiting for initial communication packet ...

  6. 一则线上MySql连接异常的排查过程

    Mysql作为一个常用数据库,在互联网系统应用很多.有些故障是其自身的bug,有些则不是,这里以前段时间遇到的问题举例. 问题 当时遇到的症状是这样的,我们的应用在线上测试环境,JMeter测试过程中 ...

  7. mysql报错排查总结

    mysql报错: [root@zabbix ~]# mysql ERROR 2002 (HY000): Can't connect to local MySQL server through sock ...

  8. Mysql 高负载排查思路

    Mysql 高负载排查思路 发现问题 top命令 查看服务器负载,发现 mysql竟然百分之两百的cpu,引起Mysql 负载这么高的原因,估计是索引问题和某些变态SQL语句. 排查思路 1. 确定高 ...

  9. Mysql异常:MySQLNonTransientConnectionException: No operations allowed after statement closed

    Mysql异常:MySQLNonTransientConnectionException: No operations allowed after statement closed MySQLNonT ...

随机推荐

  1. HTTPS 指南

    苹果在 WWDC 2016 上宣布:2016 年底将要求所有 APP 适配苹果的 App Transport Security,简单地说就是除了特殊情况(浏览器.第三方服务.媒体)外,APP 跟服务端 ...

  2. 寻找自己的道路——与技术同胞共勉 一种划分为七个阶段的道路:自信=>意志=>布局=>切入点=>团队=>渠道=>产品

    寻找自己的道路——与技术同胞共勉 每个人的幸福都是不一样的.我喜欢田园式的生活,在人多的地方总是不舒服. 对我来说,最幸福莫过于在工作中做着自己喜欢的事情.闲暇时,在能够眺望江边的地方,端着一杯红酒, ...

  3. JAVA List删除时需注意的地方

    JAVA的LIST在删除时,一般会用list.remove(o); 但这样往往会出现问题,先来看下面的这段代码: package com.demo; import java.util.ArrayLis ...

  4. MySQL慢查询mysqlsla

    转:http://www.osyunwei.com/archives/7659.html 必须在MySQL服务器上安装mysqlsla 1.mysqlsla是perl编写的脚本,运行mysqlsla需 ...

  5. Docker 简单查看name和ip

    原文地址:https://blog.csdn.net/wen_1108/article/details/78282268 查看docker name: sudo docker inspect -f=' ...

  6. 使用SQL Server发送邮件时遇到的诡异事件

    最近公司要实现一个邮件群发的功能,因此设计时就考虑用SQL Server的邮件发送功能直接推送邮件算了. 可是在实现的过程中,邮件内容中有一个表格的内容要展现,于是就编排了一个表格来实现. 具体实现如 ...

  7. Transparent Huge Pages

    在RHEL6中,透明大页功能是默认开启的. 开启该选项后,内核会尽可能地尝试分配大页,如果mmap区域是2mb,那么每个linux进程都会分配到2mb大小的页.如果大页不够用了(比如物理内存不够了), ...

  8. Lighttpd1.4.20源代码分析 笔记 状态机之错误处理和连接关闭

    这里所说的错误有两种: 1.http协议规定的错误,如404错误. 2.server执行过程中的错误.如write错误. 对于http协议规定的错误,这里的"错误"是针对clien ...

  9. C++中的成员对象

    原文链接: http://blog.csdn.net/rhzwan123/article/details/2105205 [概念] 成员对象:当一个类的成员是另一个类的对象时,这个对象就叫成员对象.概 ...

  10. 源码安装mysql 5.7.19数据库

    1.系统要求yum install -y cmake make gcc gcc-c++ bison  ncurses ncurses-devel 2.创建用户和组groupadd mysql & ...