zoukankan      html  css  js  c++  java
  • 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 -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/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/*.sock
    srwxrwxrwx. 1 mysql mysql 0 Mar 16 14:21 /tmp/db.sock
    [root@centos7-db01 ~]# mysql -uroot -p
    Enter 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=mysql
    basedir=/application/mysql
    datadir=/data/mysql/data
    socket=/tmp/db.sock
    server-id=6
    port=3306
    log-error=/data/mysql/data/db3306.err
    #[测试]
    [root@centos7-db01 ~]# mysqld_safe --defaults-file=~/db.cnf &
    [root@centos7-db01 ~]# ll /tmp/*.sock
    srwxrwxrwx. 1 mysql mysql 0 Mar 16 14:49 /tmp/db.sock
    [root@centos7-db01 data]# mysql -uroot -p
    Enter 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 -p
    Enter 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 -p
    Enter 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文件。
  • 相关阅读:
    VS2013 update4+Cocos2d-x 3.7 Win8下安装方法及配置
    它处资料:二分图最大匹配的匈牙利算法
    DataGuard备库ORA-01196故障恢复一则
    Leetcode41: Remove Duplicates from Sorted List
    BEGINNING SHAREPOINT® 2013 DEVELOPMENT 第3章节--SharePoint 2013 开发者工具 使用Napa开发SharePoint应用程序
    关于OC的内存管理-01
    P2002 消息扩散
    P1726 上白泽慧音
    2594 解药还是毒药
    P3385 【模板】负环
  • 原文地址:https://www.cnblogs.com/theboy/p/12505940.html
Copyright © 2011-2022 走看看