博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
mysql Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2)
阅读量:7297 次
发布时间:2019-06-30

本文共 732 字,大约阅读时间需要 2 分钟。

错误原因:/var/lib/mysql目录中socket文件不存在。

连接mysql服务器有两种方式:tcp连接,通过socket文件连接。通过socket文件,启动mysql服务,mysql服务会自动生成一个sock文件,生成的sock文件默认放在 --datadir=/var/lib/mysql,mysql默认从/var/lib/mysql目录读取sock文件。

解决办法:

1、看看/var/lib/mysql/mysql 有没有mysql.sock文件
2、没有mysql.sock,重启mysql服务,看看有没有。
3、没有的话,ps aux|grep mysql|grep -v 'grep' 查看mysql服务生成的sock在哪个目录,看看这个目录有没有。
4、如果mysql服务生成在其他目录,解决办法有:
方法一、修改mysql服务生成的目录,在my.cnf 中[mysqld] socket
方法二、mysql从/var/lib/mysql/读取sock文件,建立一个软连接,或者copy过来
方法三、修改mysql读取的目录,在my.cnf 中[mysql] socket
方法四、启动指定socket,mysql -uroot -p123456 --socket='/var/lib/mysql/mysql.sock'
注意:
1、通过socket,只能在本地机器上连接。
2、使用-hlocalhost就是经过socket,不经过网络,通过netstat 看不到tcp连接,可以认为mysql与mysql.sock文件交互,向里面写数据,从里面读取数据。
3、使用-h127.0.0.1就是经过tcp,通过netstat 可以看到连接。

转载地址:http://mdfnm.baihongyu.com/

你可能感兴趣的文章
P1088 火星人
查看>>
C# 单精度转换双精度丢失的问题
查看>>
ubantu 安装杀毒软件 clamav
查看>>
Number Sequence
查看>>
第12周学习进度总结
查看>>
vim末行模式下相关操作+配置文件
查看>>
產生隨機數
查看>>
用IKVMC将jar转成dll供c#调用
查看>>
Google Code Jam 2009 Qualification Round Problem B. Watersheds
查看>>
C#创建Oracle中的几何对象:点、线、面
查看>>
关于页面无法实现高度100%的原因及实现方法。
查看>>
国外期刊
查看>>
asp.net MVC发布iis无法加载css,js和图片
查看>>
js获取项目根路径
查看>>
C#当中的BeginInvoke和EndInvoke
查看>>
Centos7 & Docker & Jenkins & ASP.NET Core 2.0 自动化发布和部署
查看>>
Socket实现java服务端与AndroidApp端数据交互
查看>>
2018/12/07 L1-033 出生年 Java
查看>>
netBeans调试时不进入java内部类(jdk源码)的方法 转载
查看>>
Linux下串口编程入门
查看>>