我有一个大问题试图连接到mysql。当我跑步时:

/usr/local/mysql/bin/mysql start

我有以下错误:

Can't connect to local MySQL server through socket '/var/mysql/mysql.sock' (38)

我有mysql。Sock在/var/mysql目录下。

在/etc/my.cnf中,我有:

[client]
port=3306
socket=/var/mysql/mysql.sock

[mysqld]
port=3306
socket=/var/mysql/mysql.sock
key_buffer_size=16M
max_allowed_packet=8M

在/etc/php.ini中有:

; Default socket name for local MySQL connects.  If empty, uses the built-in
; MySQL defaults.
mysql.default_socket = /var/mysql/mysql.sock

我已经使用sudo /opt/local/apache2/bin/apachectl restart重启apache

但还是有误差。

否则,我不知道这是否相关,但当我执行mysql_config——sockets时,我得到

--socket         [/tmp/mysql.sock]

当前回答

有很多潜在的问题会导致这个错误。正如另一个回答中所建议的,最好的方法是检查日志文件。这可以在不同的位置找到,这取决于平台。对我来说,它位于/var/log/mysqld.错误是“设备上没有剩余空间”。在做了一些清理之后,我可以启动服务,问题就解决了。

其他回答

如果您使用的是AWS (Amazon Web Services)微型版本,则是内存问题。当我奔跑

mysql

从终端它会说

ERROR 2002 (HY000): Can't connect to local MySQL server through socket /var/run/mysqld/mysqld.sock' (111)

所以我尝试了下面的方法,但它会失败。

service mysqld restart

经过大量的搜索,我发现你必须为MySQL创建一个交换文件以获得足够的内存。说明如下:http://www.prowebdev.us/2012/05/amazon-ec2-linux-micro-swap-space.html。

然后,我可以重新启动mysqld。

sudo service mysql start

这应该对你很有用。有可能您更改了一些影响mysql配置的命令。

你确定你安装了MySQL和MySQL服务器吗?

例如,要安装MySQL服务器,我将使用yum或apt安装MySQL命令行工具和服务器:

yum -y install mysql mysql-server (or apt-get install mysql mysql-server)

启动MySQL服务:

/sbin/chkconfig mysqld on

启动MySQL服务器:

/sbin/service mysqld start

然后设置MySQL root密码:

mysqladmin -u root password 'new-password' (with the quotes)

我得到了以下错误:

ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock' (111)

尝试了几种方法,最终通过以下方法解决:

sudo gksu gedit /etc/mysql/my.cnf

修改:

#bind-address       = 127.0.0.1

to:

bind-address        = localhost

并重新启动:

sudo /etc/init.d/mysql restart

它工作。

sudo service mysqld start

对我有用,我用Centos