在使用命令
yum list mysql-server 安装mysql的时候,发现没有mysql的包。这时候,我们需要下载一个
下载包
wget http://repo.mysql.com/mysql-community-release-el7-5.noarch.rpm
下载完成,安装mysql-community-release-el7-5.noarch.rpm包
安装mysql
sudo yum install mysql-server
等待安装完成....
然后选择Y
安装完成后,mysql没有密码需要重置密码才行。
mysql -u root
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行... [client] default-character-set=utf8 socket=/storage/db/mysql/mysql.sock [mysql] default-character-set=utf8 socket=/storage/db/mysql/mysql.sock
原文地址:http://www.aiezu.com/db/mysql_cant_connect_through_socket.html
如果仍解决不了问题,可尝试下面的操作:
Check below things to fix the issue Check the permission of mysql data dir using below command # ls -ld /var/lib/mysql/ Check the permission of databases inside mysql data dir using below command # ls -lh /var/lib/mysql/ Check the listening network tcp ports using below command # netstat -ntlp Check the mysql log files for any error using below command. # cat /var/log/mysql/mysqld.log Try to start mysql using below command # mysqld_safe --defaults-file=/etc/my.cf
修改密码:
# mysql -uroot -p Enter password: 【输入原来的密码】(如果安装完mysql第一次设置root密码,则直接回车) mysql>use mysql; mysql> update user set password=password("123456") where user='root'; mysql> flush privileges; mysql> exit;