通过socket连接mysql_MySQL通过本地socket方式无法正常连接数据库可能出现的原因...

本文详细介绍了MySQL通过socket连接数据库时可能遇到的问题,包括配置文件中的socket路径不一致、自定义配置覆盖、服务未启动和socket文件缺失等,并提供了相应的解决方法。
摘要由CSDN通过智能技术生成

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 -p

Enter 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/m

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值