[MySQL] ERROR 2002(HY000): Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.

1 故障描述

测试环境Cacti页面登陆失败,sa找我排查问题,sa找我看是否是DB故障

2 去db服务器check。

[root@xxxx mysqldata]# ps-eaf|grep mysql

root1422 12582 0 03:48 pts/13 00:00:00 grep mysql

root1961 1 0 Sep02 ? 00:00:03 /bin/sh /usr/bin/mysqld_safe--datadir=/opt/mysqldata --socket=/var/lib/mysql/mysql.sock--pid-file=/opt/mysqldata/mysqld.pid --basedir=/usr --user=mysql

mysql15117 1961 3 03:44 ? 00:00:08 /usr/libexec/mysqld--basedir=/usr --datadir=/opt/mysqldata --user=mysql--log-error=/opt/mysqldata/mysqld.log --pid-file=/opt/mysqldata/mysqld.pid--socket=/var/lib/mysql/mysql.sock

root31480 6972 0 Sep17 pts/8 00:00:00 mysql -uroot -px xxxxxxx

[root@xxxx mysqldata]#

OK,mysql进程一切正常,在后台运行着,没有被kill掉。

3 用root登陆check里面的mysql线程

[root@xxxx mysqldata]# mysql-uroot -p

Enter password:

ERROR 2002 (HY000): Can't connect to localMySQL server through socket '/var/lib/mysql/mysql.sock' (111)

[root@eanltrsutl001 mysqldata]#

4 去查看mysql的error日志

在2的步骤里面已经看到了--log-error=/opt/mysqldata/mysqld.log参数,所以去打开error日志文件/opt/mysqldata/mysqld.log

[root@xxxx mysqldata]# tail –f /opt/mysqldata/mysqld.log

1309303:39:50 InnoDB: Started; logsequence number 3 3403486393

1309303:39:50 [ERROR] /usr/libexec/mysqld: Error writing file'/opt/mysqldata/mysqld.pid' (Errcode: 28)

1309303:39:50 [ERROR] Can't start server: can't create PID file: No space lefton device

130930 03:39:50 mysqld_safe Number ofprocesses running now: 0

130930 03:39:50 mysqld_safe mysqldrestarted

1309303:39:50 InnoDB: Initializingbuffer pool, size = 15.0G

1309303:39:51 InnoDB: Completedinitialization of buffer pool

InnoDB: The log sequence number in ibdatafiles does not match

InnoDB: the log sequence number in theib_logfiles!

1309303:39:51 InnoDB: Database was notshut down normally!

InnoDB: Starting crash recovery.

InnoDB: Reading tablespace information fromthe .ibd files...

InnoDB: Restoring possible half-writtendata pages from the doublewrite

InnoDB: buffer...

1309303:39:51 InnoDB: Started; logsequence number 3 3403486393

130930 3:39:51 [ERROR] /usr/libexec/mysqld: Errorwriting file '/opt/mysqldata/mysqld.pid' (Errcode: 28)

130930 3:39:51 [ERROR] Can't start server: can'tcreate PID file: No space left on device

130930 03:39:51 mysqld_safe Number ofprocesses running now: 0

130930 03:39:51 mysqld_safe mysqldrestarted

1309303:39:51 InnoDB: Initializingbuffer pool, size = 15.0G

看到了有没有,No space left ondevice,肯定是磁盘满了,导致无法wrote了。

5 去check磁盘空间

[root@xxxx mysqldata]# df -h

Filesystem Size Used Avail Use% Mounted on

/dev/mapper/Sys-root 1008M 513M445M 54% /

tmpfs 15G0 15G 0% /dev/shm

/dev/mapper/Sys-applog

50G 14G34G 29% /applog

/dev/vda1 194M 33M152M 18% /boot

/dev/mapper/Sys-home 2.0G68M 1.9G 4% /home

/dev/mapper/Sys-opt 20G19G 0 100%/opt

/dev/mapper/Sys-tmp 7.9G3.4G 4.2G 45% /tmp

/dev/mapper/Sys-usr 2.0G1.9G 41M 98% /usr

/dev/mapper/Sys-var 7.9G4.4G 3.2G 58% /var

/dev/mapper/Sys-crash

2.0G 68M1.9G 4% /var/crash

/dev/mapper/Sys-log 7.9G1.3G 6.3G 17% /var/log

/dev/mapper/Sys-vtmp 1008M 34M924M 4% /var/tmp

//10.15.41.252/share 466G23G 444G 5% /applog/winshare

果然是磁盘满了,/opt目录都100%了,赶紧通知sa清理磁盘空间,sa将磁盘扩充到了40G

6 root登陆check mysql db状态

[root@xxxx mysqldata]# mysql-uroot -p
Enter password:
ERROR 1045 (28000): Access denied for user'root'@'localhost' (using password: NO)
[root@xxxx mysqldata]#


PSOK,好了,磁盘满了之后,只要加大磁盘空间,mysql会自动恢复各种clients连接操作的。

7 善后

由于这台是测试服务器的cacti监控应用db服务器,所以部署安装完db后,提醒sa添加磁盘监控,但是dev部门说没事量不大,sa忙碌别的事情就没有来得及加磁盘监控。

看来还得及时提醒sa去添加磁盘监控,dev的经验也不是100%靠谱啊!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' 是一个常见的MySQL连接错误。它表示MySQL客户端无法通过指定的socket文件连接到本地MySQL服务器。 这个错误通常有几种可能的原因和解决方法: 1. MySQL服务器未运行:首先,请确保MySQL服务器正在运行。您可以使用命令`systemctl status mysql`检查MySQL服务的状态。如果MySQL没有运行,请使用`systemctl start mysql`命令启动它。 2. MySQL连接配置错误:检查连接配置文件(通常是`/etc/my.cnf`或`/etc/mysql/my.cnf`)。确保配置文件中的socket路径与实际的socket文件路径匹配。如果路径不正确,可以手动编辑配置文件并将其更正。 3. socket文件不存在或权限问题:检查指定的socket文件`/var/lib/mysql/mysql.sock`是否存在,并且具有正确的权限。如果文件不存在,可以尝试重新创建它,并确保它所在的目录具有正确的权限。您可以使用以下命令进行验证: ``` ls -l /var/lib/mysql/mysql.sock ``` 4. MySQL服务器监听地址错误:MySQL服务器可能只监听特定的IP地址或主机名。请确保您连接MySQL服务器时使用的是正确的主机名或IP地址。您可以尝试使用`-h`选项指定正确的主机名,例如: ``` mysql -h localhost ``` 希望这些解决方法能够帮助您解决ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock'错误。如果问题仍然存在,请提供更多详细信息以便我能够提供进一步的帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值