我有一个大问题试图连接到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]

当前回答

CentOS 7, 64位。新的安装。 在我的例子中,这个错误是因为我没有安装正确的MySQL服务器和MySQL客户端。 使用yum,我删除了mariadb和mysql社区版。我从MySQL官方网站下载了客户端和服务器的rpm,并安装了服务器和客户端。

在安装服务器时,我看到一条消息,MySQL root帐户的密码存储在一个文件中,我可以用sudo cat /root/.mysql_secret查看。

所以在安装客户端和服务器后,我用命令sudo service MySQL status检查MySQL是否正常工作(我想我在这样做之前重新启动了),我得到了结果。

MySQL运行(2601)[OK]

我使用.mysql_secret文件中的密码登录MySQL: mysql -uroot -pdxM01Xfg3DXEPabpf。注意,dxM01Xfg3DXEPabpf是.mysql_secret文件中提到的密码。

然后在mysql提示符下输入以下命令修改root的密码:

mysql> SET PASSWORD FOR 'root'@'localhost' = PASSWORD('somePassword');

从那以后,一切都很顺利。

其他回答

你确定你安装了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)

如果你正在重新安装mariadb,你必须检查mysql的旧进程是否还在运行,找到并杀死这个进程

ps ax | grep mysql

sudo kill -9 mysql

因为InnoDB会自动重启,你可以使用kill -15 如需重新安装*删除目录

sudo rm -rf /var/lib/mysql

创建一个默认的数据库结构并引导mariadb读取数据目录

sudo mysql_install_db --user=mysql --basedir=/usr --datadir=/var/lib/mysql

然后重新配置

sudo mysql_secure_installation

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

我今天遇到了这个问题。这些答案都不能解决问题。我需要做以下命令(在这里找到https://stackoverflow.com/a/20141146/633107)为我的mysql服务启动:

sudo /etc/init.d/mysql stop
cd /var/lib/mysql/
ls ib_logfile*
mv ib_logfile0 ib_logfile0.bak
mv ib_logfile1 ib_logfile1.bak
... etc ...
/etc/init.d/mysql restart

这部分是由/var/log/mysql/error.log中的以下错误指示的:

140319 11:58:21 InnoDB: Completed initialization of buffer pool
InnoDB: Error: log file ./ib_logfile0 is of different size 0 50331648 bytes
InnoDB: than specified in the .cnf file 0 5242880 bytes!
140319 11:58:21 [ERROR] Plugin 'InnoDB' init function returned error.
140319 11:58:21 [ERROR] Plugin 'InnoDB' registration as a STORAGE ENGINE failed.
140319 11:58:21 [ERROR] Unknown/unsupported storage engine: InnoDB
140319 11:58:21 [ERROR] Aborting

我还看到磁盘已满错误,但只有在运行没有sudo的命令时。如果权限检查失败,则报告磁盘已满(即使您的分区还没有接近满)。

如果你的my.cnf文件(通常在/etc/mysql/文件夹中)正确配置了:

socket=/var/lib/mysql/mysql.sock

可以使用以下命令检查mysql是否正在运行:

mysqladmin -u root -p status

尝试更改mysql文件夹的权限。如果你在当地工作,你可以尝试:

sudo chmod -R 755 /var/lib/mysql/

这为我解决了问题。