当前位置: 首页 >数据库 > ERROR:Can't connect to local MySQL server through socket可能出现的情况

ERROR:Can't connect to local MySQL server through socket可能出现的情况


1.在/etc/my.cnf配置文件中,mysqld和mysql标签对应的socket文件路径不对等

#[环境准备][root@centos7-db01 ~]# vim /etc/my.cnf[mysqld]socket=/tmp/mysql.sock[mysql]socket=/tmp/db.sock#[测试][root@centos7-db01 ~]# systemctl restart mysqld[root@centos7-db01 ~]# mysql -uroot -pEnter password: ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/db.sock' (2)

PS:mysql客户端通过db.sock套接字去连接数据库, 但是/tmp/db.sock文件服务启动时未被创建,导致连接失败。

2.在一个或多个配置文件中,启用了/etc/my.cnf文件相同的参数

命令:mysqld --help --verbose|grep my.cnf,查看mysqld程序启动过程中,读取配置文件的顺序。

/etc/my.cnf /etc/mysql/my.cnf /usr/local/mysql/etc/my.cnf ~/.my.cnf

#[环境准备][root@centos7-db01 ~]# vim /etc/my.cnf[mysqld]socket=/tmp/mysql.sock[mysql]socket=/tmp/mysql.sock#添加用户自定义配置[root@centos7-db01 ~]# vim ~/.my.cnf[mysqld]socket=/tmp/db.sock#[测试][root@centos7-db01 ~]# /etc/init.d/mysqld restart[root@centos7-db01 ~]# ll /tmp/*.socksrwxrwxrwx. 1 mysql mysql 0 Mar 16 14:21 /tmp/db.sock[root@centos7-db01 ~]# mysql -uroot -pEnter password: ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)

PS:参数优先级,mysqld或mysqld_safe命令行方式 > --defaults-file指定配置文件 > 默认配置文件。

3.使用--defaults-file参数强制启用自定义配置

#[环境准备]#只更新了mysqld服务端的socket参数,未对mysql客户端对应参数进行更新[root@centos7-db01 ~]# vim db.cnf[mysqld]user=mysqlbasedir=/application/mysqldatadir=/data/mysql/datasocket=/tmp/db.sockserver-id=6port=3306log-error=/data/mysql/data/db3306.err#[测试][root@centos7-db01 ~]# mysqld_safe --defaults-file=~/db.cnf &[root@centos7-db01 ~]# ll /tmp/*.socksrwxrwxrwx. 1 mysql mysql 0 Mar 16 14:49 /tmp/db.sock[root@centos7-db01 data]# mysql -uroot -pEnter password: ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)

PS: --defaults-file指定配置文件参数,覆盖了默认配置文件对应的参数信息。

4.MySQL服务未启动

[root@centos7-db01 ~]# netstat -lntp|grep mysql[root@centos7-db01 ~]# mysql -uroot -pEnter password: ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)

5.误删除socket文件

[root@centos7-db01 tmp]# mv mysql.sock{,.bak}[root@centos7-db01 tmp]# mysql -uroot -pEnter password: ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)

说明:

  1. 尽可能将参数配置到/etc/my.cnf文件中,方便管理。
  2. 针对同一个实例,client端标签和server端标签对应的socket文件路径需配置一致。
  3. 多实例可以使用--defaults-file参数指定配置文件来启动服务。
  4. 可以结合error log日志,获知当前启用的socket文件。

作者:The^_^Boy
来源链接:https://www.cnblogs.com/theboy/p/12505940.html

版权声明:
1、JavaClub(https://www.javaclub.cn)以学习交流为目的,由作者投稿、网友推荐和小编整理收藏优秀的IT技术及相关内容,包括但不限于文字、图片、音频、视频、软件、程序等,其均来自互联网,本站不享有版权,版权归原作者所有。

2、本站提供的内容仅用于个人学习、研究或欣赏,以及其他非商业性或非盈利性用途,但同时应遵守著作权法及其他相关法律的规定,不得侵犯相关权利人及本网站的合法权利。
3、本网站内容原作者如不愿意在本网站刊登内容,请及时通知本站(javaclubcn@163.com),我们将第一时间核实后及时予以删除。





本文链接:https://www.javaclub.cn/database/118352.html

分享给朋友:

“ERROR:Can't connect to local MySQL server through socket可能出现的情况” 的相关文章

全面解析Redis 2022年05月13日 10:22:02
MySQL面试有这一篇就够了 2022年05月16日 21:53:45
MYSQL的存储过程 2022年05月16日 21:54:19
mysql 查询1小时内 2022年06月06日 12:59:30
mysql查询结果中文显示成了问号 2022年06月07日 02:00:43