cant connect local mysql to_连接Mysql提示Can't connect to local MySQL server through socket的解决方法...
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的解决方法...相关推荐
- 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 ...
- 连接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 ...
- 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 ...
- 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 ...
- MySql 数据库 - 安装时提示缺失VCRUNTIME140_1.dll文件导致的无法启动此程序解决方法,vc++2015-2019运行库集合包获取
VCRUNTIME140_1.dll 是 vc++ 运行库里的 dll 文件,缺失这个只需要我们把 vc++ 运行库重新装下就好了. 我这提供了 vc++2015-2019 的集合安装包,可以一键解决 ...
- mysql 10055 解决方案_Can't connect to MySQL server on'localhost' (10055)解决方法
今天朋友的windows服务器上的站点突然访问出错,提示数据库连接错误,叫帮忙看一下... 检察服务器发现没有异常,数据库密码没有改,难道是mysql停止了,没有启动? 然后分别执行一下net sto ...
- 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显示 ...
- 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添加 ...
- scp连接linux网络错误,winscp连接linux(centos7)时提示主机超过15秒无通信,继续等待的解决方法...
1. 前言 本文主要讲解winscp连接linux(centos7)时提示主机超过15秒无通信,继续等待的解决方法 2. winscp报错界面 winscp报错界面如下: 解决方法如下: 3. 确保网 ...
最新文章
- mssql mysql 语法区别_mssql与mysql区别之——变量区别
- DCIC共享单车数据可视化教程!
- 交互式讲解傅里叶变换
- 2017-2018-1 20155336 《信息安全系统设计基础》加分作业:实现mypwd
- Mongodb监控指标
- 数据仓库、商业智能的体系结构
- python 实例方法和类方法的区别_python中实例方法,类方法和静态方法的区别。...
- 60-200-072-使用-命令-MySQL使用mysqldumpslow分析慢查询日志文件
- 运维架构师-并不遥远的彼岸
- nginx -- 负载均衡
- python学习点滴记录-Day01
- MATLAB中的数组
- 简单区分一级域名、二级域名、三级域名
- Python oct()函数
- Mysql原理篇之索引不懂不要瞎用---04
- Android虚拟机的安装
- 用python画小鸭_python中的鸭子类型(协议)和接口
- 如何利用安卓手机搭建WEB服务器
- STM32H743使用PA0,PA1作为ADC输入的坑!!
- C++ 函数实参传递 (argument passing)