mysql登录时报socket找不到的问题及解决

 更新时间:2024年07月16日 11:01:01   作者:我是李超人  
这篇文章主要介绍了mysql登录时报socket找不到的问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

mysql登录时报socket找不到

mysqld.socket文件是用来给客户端和服务端进行通信的,如果通过源码方式安装,默认情况下这个文件会被放在tmp目录下。

当然也可以手动指定存放位置,通过修改/etc/my.cnf文件的socket参数来修改mysqld.socket的存放路径。

例如:

[mysqld]
socket=/data/mysqldb/mysqld.sock

但是这样一来在登录的时候就会出现如下问题

[root@s186 /data/mysql]#/usr/local/mysql/bin/mysql -uroot -p
Enter password: 
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)

mysql客户端在登录的时候默认会去/tmp/mysql.sock这个目录查找mysqld.socket文件,由于修改了路径自然是找不到的。

可以通过修改/etc/my.cnf文件给客户端指定位置。

添加如下配置:

[client]
socket=/data/mysqldb/mysqld.sock

这样客户端在登录时就会去指定的目录查找mysqld.socket文件,

注意client的socket要和mysqld是一样的,因为客户端和服务端通信靠的就是这个文件,肯定要一致

通过上面的案例应该明白为何服务端可以启动,但是登录的时候会报socket找不到的问题了。

出现socket找不到的问题大致有以下几种情况

1.mysqld和client的socket配置路径不一样

比如像下面这样的配置

[mysqld]
socket=/data/mysqldb/mysqld.sock
[client]
socket=/data/mysqldb/mysql.sock

路径是一样的,但是文件名不一样,一个是mysqld.socket,一个是mysql.socket

socket文件是由服务端生成的,而客户端找的就是服务端生成的socket文件,所以client的配置要和mysqld一样

2.在cmake的时候指定了路径

比如像下面这一段cmake指令

在参数DMYSQL_UNIX_ADDR=/tmp/mysqld.sock中指定了socket的位置

那么/etc/my.cnf上mysqld上的socket和client上的socket都需要和这个一致

因为cmake在执行完之后,mysqld这个执行文件才会生成,并且这个执行文件中会记录你指定的参数

那么当执行mysqld的时候,它就会在你指定的目录下去查找

这个时候/etc/my.cnf下的mysqld和client的socket必须和指定的路径保持一致

否则mysqld执行都会失败(会报change dir…这样的错误)

cmake \-DCMAKE_INSTALL_PREFIX=/usr/local/mysql56 -DMYSQL_DATADIR=/data/mysqldb/data -DSYSCONFDIR=/etc/my.cnf  -DWITH_MYISAM_STORAGE_ENGINE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_MEMORY_STORAGE_ENGINE=1 -DWITH_READLINE=1 -DMYSQL_UNIX_ADDR=/data/mysqld.sock -DMYSQL_TCP_PORT=3306 -DENABLED_LOCAL_INFILE=1 -DWITH_PARTITION_STORAGE_ENGINE=1 -DEXTRA_CHARSETS=utf8 -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci

解决方法

解决socket的核心就是在登录的时候告诉客户端socket文件的位置

要么通过/etc/my.cnf文件指定位置

要么就是在登录的时候指定位置

像下面这样:

mysql -uroot -p --socket=/data/mysqldb/mysqld.sock

还有一种方式就是创建软连接,因为客户端默认会到/tmp下找mysqld.socket文件

我不通过配置文件,在tmp下建一个软连接就可以了

ln -s /data/mysqldb/mysqld.sock mysql.socket

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • mysql #1062 –Duplicate entry ''1'' for key ''PRIMARY''

    mysql #1062 –Duplicate entry ''1'' for key ''PRIMARY''

    Mysql进行数据备份,还原后进行回帖,出现以下错误代码,其实主要是导入数据重复的问题,将现在的数据表清空,重新导入即可
    2012-07-07
  • Mysql的max_allowed_packet设定

    Mysql的max_allowed_packet设定

    今天小编就为大家分享一篇关于Mysql的max_allowed_packet设定,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2018-12-12
  • mysql数据库备份设置延时备份方法(mysql主从配置)

    mysql数据库备份设置延时备份方法(mysql主从配置)

    这篇文章主要介绍了mysql数据库延时备份的方法,也就是mysql主从服务器备份,可以同步到多个服务器,最后我们提供了一个备份脚本,大家参考使用吧
    2013-12-12
  • replace MYSQL字符替换函数sql语句分享(正则判断)

    replace MYSQL字符替换函数sql语句分享(正则判断)

    最近更新网站发现一些字段的值不是预期的效果,需要替换下值,通过下面的sql语句,直接执行就可以了
    2012-06-06
  • MySQL使用MRG_MyISAM(MERGE)实现分表后查询的示例

    MySQL使用MRG_MyISAM(MERGE)实现分表后查询的示例

    这篇文章主要介绍了MySQL使用MRG_MyISAM(MERGE)实现分表后查询的示例,帮助大家更好的理解和使用MySQL数据库,感兴趣的朋友可以了解下
    2020-12-12
  • Servermanager启动连接数据库错误如何解决

    Servermanager启动连接数据库错误如何解决

    这篇文章主要介绍了Servermanager启动连接数据库错误如何解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-10-10
  • MySQL语句执行顺序和编写顺序实例解析

    MySQL语句执行顺序和编写顺序实例解析

    这篇文章主要介绍了MySQL语句执行顺序和编写顺序实例解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-06-06
  • 运维角度浅谈MySQL数据库优化(李振良)

    运维角度浅谈MySQL数据库优化(李振良)

    一个成熟的数据库架构并不是一开始设计就具备高可用、高伸缩等特性的,它是随着用户量的增加,基础架构才逐渐完善。这篇博文主要谈MySQL数据库发展周期中所面临的问题及优化方案
    2015-07-07
  • MYSQL大量写入问题优化详解

    MYSQL大量写入问题优化详解

    这篇文章主要介绍了MYSQL大量写入问题优化详解,文中优化点解释的很清楚,让人看完就明了,感兴趣的同学可以阅读理解下
    2021-03-03
  • mysql的启动过程详解

    mysql的启动过程详解

    这篇文章主要介绍了mysql的启动过程详解,本文用生动风趣的文风讲解了mysql的启动过程,绝对让你难忘哦,需要的朋友可以参考下
    2014-08-08

最新评论