mysql,mysqldump,mysqldump,php连接mysql服务常会提示下面错误:

ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2)

产生此问题的原因一般有两个:

1、mysql服务未正常运行:

由于mysql的socket文件是由mysqld服务启动时创建的,如果mysqld服务未正常启动,socket文件自然也不会被创建,当然会找不到socket文件了。对于判断mysql服务是否启动,我们可以使用下面命令:

# 1、 端口是否打开

[root@aiezu.com ~]# lsof -i:3306

COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME

mysqld 12207 mysql 14u IPv4 52350 0t0 TCP *:mysql (LISTEN)

# 2、mysqld服务是否正在运行

[root@aiezu.com ~]# service mysqld status

mysqld (pid 4717) is running...

2、socket文件路径在配置文件中设置不完整:

这一般是由于我们修改了mysql配置“/etc/my.cnf”引起的。比如我们修改了配置文件中“[mysql]”选项下的“socket”参数,而未指定“[client]”、“[mysql]”选项的“socket”参数,导致mysql使用默认的socket文件位置去寻找socket文件,从而导致未找到socket文件而引发此错误。

解决办法:

1、mysql服务未正常运行:

如果是服务未启动,我们运行“service mysqld start”启动服务即可。如果服务启动不了,就去查看mysql服务日志,寻找原因并解决再启动

[root@aiezu.com ~]# service mysqld start

Starting mysqld: [ OK ]

[root@aiezu.com ~]# lsof -i:3306

COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME

mysqld 14109 mysql 10u IPv4 247183583 0t0 TCP *:mysql (LISTEN)

[root@aiezu.com ~]# service mysqld status

mysqld (pid 14109) is running...

2、完善mysql配置文件:

如果确认mysql服务正常运行,还提示文章标题的此错误,那就是“/etc/my.cnf”配置文件的问题了。解决办法是修改“/etc/my.cnf”配置文件,在配置文件中添加“[client]”选项和“[mysql]”选项,并使用这两个选项下的“socket”参数值,与“[mysqld]”选项下的“socket”参数值,指向的socket文件路径完全一致。如下:

[mysqld]

datadir=/storage/db/mysql

socket=/storage/db/mysql/mysql.sock

...省略n行(爱E族)...

[client]

default-character-set=utf8

socket=/storage/db/mysql/mysql.sock

[mysql]

default-character-set=utf8

socket=/storage/db/mysql/mysql.sock

其中socket等于的路径就是socket文件的位置,我们只要修改my.cnf文件,告诉mysql,mysqldump,mysqladmin等命令,mysql服务的socket文件位置在哪里,然后重启mysqld服务即可。

3、php连接mysql服务提示"Can't connect to local MySQL server through socket..."的解决方法有时候mysql服务正常运行,用户名密码也完全正确,使用php的mysql_connect函数却连接不了mysql,调用php的mysql_error()函数提示“Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock'”,这是我们需要修改/etc/php.ini文件。

在/etc/php.ini文件中"[MySQL]"项下找到"mysql.default_socket",并设置其值指向正确的mysql服务socket文件即可,如:

[MySQL]

...省略n行...

mysql.default_socket = "/storage/db/mysql/mysql.sock"

4、python连接mysql提示"Can't connect to local MySQL server through socket..."的解决方法:在连接mysql数据库函数中指定socket文件,如下:

#!/usr/bin/python

from MySQLdb import connect

conn = connect(db="pzy", user="root", host="localhost", unix_socket="/storage/db/mysql/mysql.sock")

cur = conn.cursor()

count=cur.execute("show databases")

print 'there has %s dbs' % count

conn.commit()

conn.close()

5. php pdo连接mysql提示"Can't connect to local MySQL server through socket..."的解决方法:同样在连接字符串添加mysql socket文件的位置即可,如下:

$dsn = "mysql:host=localhost;dbname=pzy;unix_socket=/storage/db/mysql/mysql.sock";

$db = new PDO($dsn, 'root', '');

$rs = $db->query("SELECT * FROM qrtest");

while($row = $rs->fetch()){

print_r($row);

}

?>

cant connect local mysql to_连接Mysql提示Can't connect to local MySQL server through socket的解决方法...相关推荐

  1. cant connect local mysql to_连接Mysql提示Can’t connect to local MySQL server through socket的解决方法...

    mysql.mysqldump.mysqladmin.php连接mysql服务常会提示下面错误:ERROR 2002 (HY000): Can't connect to local MySQL ser ...

  2. 连接Mysql提示Can’t connect to local MySQL server through socket的解决方法

    mysql,mysqldump,Mysqladmin,php连接mysql服务常会提示下面错误: ERROR 2002 (HY000): Can't connect to local MySQL se ...

  3. ERROR 2002 (HY000): Cant connect to local MySQL server through socket的解决方法

    连接MySQL提示ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2 ...

  4. Can’t connect to local MySQL server through socket的解决方法

    Can't connect to local MySQL server through socket的解决方法 参考文章: (1)Can't connect to local MySQL server ...

  5. MySql 数据库 - 安装时提示缺失VCRUNTIME140_1.dll文件导致的无法启动此程序解决方法,vc++2015-2019运行库集合包获取

    VCRUNTIME140_1.dll 是 vc++ 运行库里的 dll 文件,缺失这个只需要我们把 vc++ 运行库重新装下就好了. 我这提供了 vc++2015-2019 的集合安装包,可以一键解决 ...

  6. mysql 10055 解决方案_Can't connect to MySQL server on'localhost' (10055)解决方法

    今天朋友的windows服务器上的站点突然访问出错,提示数据库连接错误,叫帮忙看一下... 检察服务器发现没有异常,数据库密码没有改,难道是mysql停止了,没有启动? 然后分别执行一下net sto ...

  7. MySQL显示ERROR 2003 (HY000): Can‘t connect to MySQL server on ‘localhost‘ (10061)解决方法

    MySQL显示ERROR 2003 (HY000): Can't connect to MySQL server on 'localhost' (10061)解决方法 参考文章: (1)MySQL显示 ...

  8. Mysql添加用户错误:ERROR 1364 (HY000): Field ‘ssl_cipher‘ doesn‘t have a default value解决方法

    Mysql添加用户错误:ERROR 1364 (HY000): Field 'ssl_cipher' doesn't have a default value解决方法 参考文章: (1)Mysql添加 ...

  9. scp连接linux网络错误,winscp连接linux(centos7)时提示主机超过15秒无通信,继续等待的解决方法...

    1. 前言 本文主要讲解winscp连接linux(centos7)时提示主机超过15秒无通信,继续等待的解决方法 2. winscp报错界面 winscp报错界面如下: 解决方法如下: 3. 确保网 ...

最新文章

  1. mssql mysql 语法区别_mssql与mysql区别之——变量区别
  2. DCIC共享单车数据可视化教程!
  3. 交互式讲解傅里叶变换
  4. 2017-2018-1 20155336 《信息安全系统设计基础》加分作业:实现mypwd
  5. Mongodb监控指标
  6. 数据仓库、商业智能的体系结构
  7. python 实例方法和类方法的区别_python中实例方法,类方法和静态方法的区别。...
  8. 60-200-072-使用-命令-MySQL使用mysqldumpslow分析慢查询日志文件
  9. 运维架构师-并不遥远的彼岸
  10. nginx -- 负载均衡
  11. python学习点滴记录-Day01
  12. MATLAB中的数组
  13. 简单区分一级域名、二级域名、三级域名
  14. Python oct()函数
  15. Mysql原理篇之索引不懂不要瞎用---04
  16. Android虚拟机的安装
  17. 用python画小鸭_python中的鸭子类型(协议)和接口
  18. 如何利用安卓手机搭建WEB服务器
  19. STM32H743使用PA0,PA1作为ADC输入的坑!!
  20. C++ 函数实参传递 (argument passing)

热门文章

  1. UVA10879 Code Refactoring【因子+暴力】
  2. 【网络/通信】概念的理解 —— 带宽、吞吐量、净荷
  3. Matlab Tricks(二十五) —— 二维图像的 shuffle
  4. 工具的使用 —— windows 实用工具
  5. 对数的应用 —— 数位(digits)的个数
  6. utilities(C/C++)(二)
  7. 黄金分割比的重新理解
  8. boost基础——variant的原理及基本用法
  9. keras 深度神经网络模型的搭建
  10. mysql读写分离java配置方法_springboot配置数据库读写分离