DB-Mysql-Can't connect to local MySQL server through socket '/var/run/mysqld/mys
错误病症:
Error: Can't connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock'
也有些类似的错误,只不过后面的socket文件不同
诊断:
#1
mysql客户端通过此文件/var/run/mysqld/mysqld.sock来连接数据库
但我并没有指定这个文件,表示这是默认使用的
$ mysql --help | grep socket
--protocol=name The protocol to use for connection (tcp, socket, pipe,
-S, --socket=name The socket file to use for connection.
The buffer size for TCP/IP and socket communication.
socket /var/run/mysqld/mysqld.sock
# 看看是不是有这个文件
命令: ll /var/run/mysqld/mysqld.sock
有些云机器上也许就没有此文件,此时可以找到一个可用的socket文件,建立一个软连接就可以了
--文件在哪里?
找到my.conf这个配置文件(ubuntu在/etc/mysql/my.conf),此文件是The MySQL database server configuration file.
打开看见
19 [client]
20 port,.,.= 3306
21 socket,.,.= /var/run/mysqld/mysqld.sock
这里配置了地址,改这里也算是一种方法。
#治病
找到mysql.sock文件,建立软连接,如我的云机器的sock文件在tmp目录,而且mysqld.sock不在默认目录:
ln -s /var/run/mysqld/mysqld.sock /tmp/mysql.sock
这样就搞定了。
有人还是不行,那就仔细看看原理,再处理吧。病理是一样的,但表征和治病的方子是变化的。
其他:启动mysql服务的时候,也可以指定sock文件:
/xxx/server/mysql/libexec/mysqld --basedir=/xxx/server/mysql --datadir=/xxx/server/mysql/var --user=mysql --log-error=/xxx/server/mysql/var/AY130422112217010a42.err --open-files-limit=16384 --pid-file=/xxx/server/mysql/var/AY130422112217010a42.pid --socket=/tmp/mysql.sock --port=3306
参考文章:http://blog.csdn.net/lmss82/article/details/4414178
1876 ? 00:00:31 mysqld
先查看 /etc/rc.d/init.d/mysqld status 看看m y s q l 是否已经启动.
另外看看是不是权限问题.
------------------------------------------------------------------------------------
[root@localhost beinan]#chown -R mysql:mysql /var/lib/mysql
[root@localhost beinan]# /etc/init.d/mysqld start
启动 MySQL: [ 确定 ]
[root@localhost lib]# mysqladmin -uroot password '123456'
[root@localhost lib]# mysql -uroot -p
Enter password:
Welcome to the MySQL monitor. Commands end with ; or /g.
Your MySQL connection id is 3 to server version: 4.1.11
Type 'help;' or '/h' for help. Type '/c' to clear the buffe他的也解决了,我的麻烦还在继续,依然继续寻找
问题解决了,竟然是max_connections=1000 他说太多了,然后改成500也说多,无奈删之问题解决了。还是不行
摘要:解决不能通过mysql .sock连接MySQL问题 这个问题主要提示是,不能通过 '/tmp/mysql .sock'连到服务器,而php标准配置正是用过'/tmp/mysql .sock',但是一些mysql 安装方法 将 mysql .sock放在/var/lib/mysql .sock或者其他的什么地方,你可以通过修改/etc/my.cnf文件来修正它,打开文件,可以看到如下的东东:[mysql d]
socket=/var/lib/mysql .sock
改一下就好了,但也会引起其他的问题,如mysql 程序连不上了,再加一点:
[mysql ]
socket=/tmp/mysql .sock
或者还可以通过修改php.ini中的配置来使php用其他的mysql .sock来连,这个大家自己去找找
或者用这样的方法:
ln -s /var/lib/mysql /mysql .sock /tmp/mysql .sock成功了,就是这样ln -s /var/lib/mysql /mysql.sock/tmp/mysql.sock
推荐阅读
-
连接Mysql提示Can’t connect to local MySQL server through socket的解决方法
-
MySQL错误 ERROR 2002 (HY000): Can't connect to local MySQL server through socket 的解决办法
-
Can't connect to local MySQL server through socket
-
linux安装MySQL后输入mysql显示 ERROR 2002 (HY000): Can't connect to local MySQL server through socket
-
【解决】Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.soc
-
ERROR 2002 (HY000): Can’t connect to local MySQL server through socket ‘/var mys
-
ERROR 2002 (HY000): Can’t connect to local MySQL server through socket ‘/var mys
-
Can't connect to local MySQL server through socket &
-
Can't connect to local MySQL server through socket解决方法_MySQL
-
Can’t connect to local MySQL server through socket 解决办法