zoukankan      html  css  js  c++  java
  • mysql Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (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 可以看到连接。

  • 相关阅读:
    深入剖析C#的多态
    .NET多线程编程:多任务和多线程
    .Net类库中实现的HashTable
    用C#编写ActiveX控件
    用微软.NET架构企业解决方案 学习笔记(四)业务层
    SQL事务
    WCF基础知识问与答
    在.NET环境中使用单元测试工具NUnit
    圣殿骑士博客转载系列
    系统架构师学习笔记_第十二章
  • 原文地址:https://www.cnblogs.com/nzbbody/p/4572712.html
Copyright © 2011-2022 走看看