mysql 2002 socket_ERROR 2002 (HY000):Can't connect to local MySQL server though socket '/var/lib/mys...

三、修复故障前准备:1、看mysql服务是否在运行:(一定要看,不要因为没有启动mysql而多走冤枉路)

[root@hadoop001 ~]# service mysql status

MySQL running (10138) [ OK ]

网上有的会推荐以下这种

[root@hadoop001 ~]# service mysqld status

然后会报错

Redirecting to /bin/systemctl status mysqld.service

Unit mysqld.service could not be found.

这是因为mysql版本的问题,低版本的用mysqld高版本的用mysql就可以。

如果显示mysql正在运行则继续往下看,若果显示没有启动,那么需要先想办法启动mysql

以下内容也许能帮到你

登录mysql出现/var/lib/mysql/mysql.sock不存在

问题描述:

1.mysql安装完成后,使用

service mysqld start

总是出现 start failed。

2.使用mysql -uroot -p登录出现找不到 /var/lib/mysql/mysql.sock问题。

3.使用service mysqld status出现 mysql dead but subsys locked(暂时还没有出现这个问题)

解决方法:

4.1 service mysqld stop (停止服务)

4.2 rm -fr /var/lib/mysql/* (删除/var/lib/mysql下的所有文件)

4.3 rm /var/lock/subsys/mysqld(删除锁定文件)

4.4 killall mysqld (杀死所有mysqld进程)

4.5 service mysql start (启动mysql服务。)

原文:https://blog.csdn.net/u013176681/article/details/67636851

由于“socket”文件是由mysql服务运行时创建的,如果提示“ERROR 2002 (HY000): Can't connect to local MySQL server through socket '***' (2)”,找不到“socket”文件,我们首先要确认的是mysql服务是否正在运行。

#1:端口是否打开

[root@lam7 opt]# lsof -i:3306COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAMEmysqld 57436 mysql 17u IPv6 160456 0t0 TCP *:mysql (LISTEN)

#2:mysqld服务是否正在运行(小七这边用的是centos7,所以会提示使用“/bin/systemctl status mysqld.service”)

[root@lam7 opt]# service mysqld statusRedirecting to /bin/systemctl status mysqld.servicemysqld.serviceLoaded: not-found (Reason: No such file or directory)Active: inactive (dead)

#3:如果mariaDB,同样方法查服务是否正在运行:

[root@lam7 opt]# service mariadb statusRedirecting to /bin/systemctl status mariadb.servicemariadb.service - MariaDB database serverLoaded: loaded (/usr/lib/systemd/system/mariadb.service; disabled)Active: inactive (dead)

#4mysqld服务是否正在运行(此现状是mysql服务正常运行)

[root@lam7 opt]# service mariadb statusRedirecting to /bin/systemctl status mariadb.service● mariadb.service - MariaDB database serverLoaded: loaded (/usr/lib/systemd/system/mariadb.service; disabled; vendor preset: disabled)Active: active (running) since 二 2016-11-22 20:09:01 CST; 10min ago

2、确定“socket”文件正确位置:  确定mysql服务正常运行后,产生此错误的原因只剩下“socket”文件路径不正确了,我们可以使用“find”命令或者“lsof”命令来确定socket文件的正确路径:

[root@lam7 opt]# lsof -c mysqld|grep sock$lsof: WARNING: can't stat() fuse.gvfsd-fuse file system /run/user/1000/gvfsOutput information may be incomplete.mysqld 57436 mysql 18u unix 0xffff88000b55f440 0t0 160457 /opt/lampp/var/mysql/mysql.sock

[root@lam7 opt]# find / -name '*.sock'/storage/db/mysql/mysql.sock

四、故障解决方法:解决方案一:  修改“/etc/my.cnf”配置文件,在/etc/php.ini文件中"[MySQL]"项下找到"mysql.default_socket",并设置其值指向正确的mysql服务socket文件即可,  在配置文件中添加“[client]”选项和“[mysql]”选项,并使用这两个选项下的“socket”参数值,与“[mysqld]”选项下的“socket”参数值,指向的socket文件路径完全一致。如下:

[mysqld]datadir=/storage/db/mysqlsocket=/storage/db/mysql/mysql.sock...省略n行[client]default-character-set=utf8socket=/storage/db/mysql/mysql.sock[mysql]default-character-set=utf8socket=/storage/db/mysql/mysql.sock

修改完后,重启mysqld服务,即可解决此问题。

解决方案二:(小七是用此方法解决的问题)  使用“ln -s /storage/db/mysql/mysql.sock /var/lib/mysql/mysql.sock”命令,将正确的socket文件位置,软链接到提示错误的socket文件路径位置,即可解决此问题:

[root@lam7 opt]# ls /var/lib/mysql/mysql.sockls: 无法访问/var/lib/mysql/mysql.sock: 没有那个文件或目录

[root@lam7 opt]# ln -s /storage/db/mysql/mysql.sock /var/lib/mysql/mysql.sock[root@lam7 opt]# ls /var/lib/mysql/mysql.sock/var/lib/mysql/mysql.sock

这边讲述了mysql提供的“mysql”、“mysqldump”、“mysqladmin”等命令提示“ERROR 2002 (HY000): Can't connect to local MySQL server through socket '***' (2)”的解决方法,如果需要解决“php”、“perl”、“python”等脚本语言提示此错误的问题

推荐博客:https://blog.csdn.net/ugfdfgg/article/details/83820200

https://www.2cto.com/database/201807/764134.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值