mysql启动时报2002_Mysql 启动时 报ERROR 2002,分析解决

本文档记录了一种MySQL客户端通过错误的socket文件无法连接到本地服务器的故障,分析了问题原因并提供了两种解决方案:一是通过修改my.cnf配置文件中mysql的socket选项,二是创建socket文件的软链接。最终成功解决了连接问题。
摘要由CSDN通过智能技术生成

1、故障现象[root@localhost scripts]# mysql -u root

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

2、故障分析

查看mysql实例的状态[root@localhost scripts]# netstat -ntlp  | grep 3306

tcp        0      0 :::3306                    :::*                        LISTEN      13001/mysqld

查看my.cnf关于socket的配置[root@localhost scripts]# more /etc/my.cnf |grep sock

socket = /tmp/mysqld.sock

也就是说mysqld已经声称了正确的sock文件,但客户端连接还是从初始目录去找sock文件

下面查看后台日志,有个ERROR,是关于满查询日志的,是由于目录不存在而产生的错误,与当前故障无关[root@localhost scripts]# more SZDB.err

............

2014-10-11 13:17:21 13001 [Note] InnoDB: 5.6.12 started; log sequence number 1625997

/app/soft/mysql/bin/mysqld: File '/log/mysql_logs/slowquery.log' not found (Errcode: 2 - No such file or directory)

2014-10-11 13:17:21 13001 [ERROR] Could not use /log/mysql_logs/slowquery.log for logging (error 2). Turning logging off for the who

le duration of the MySQL server process. To turn it on again: fix the cause, shutdown the MySQL server and restart it.

2014-10-11 13:17:21 13001 [Note] Server hostname (bind-address): '*'; port: 3306

2014-10-11 13:17:21 13001 [Note] IPv6 is available.

2014-10-11 13:17:21 13001 [Note]  - '::' resolves to '::';

2014-10-11 13:17:21 13001 [Note] Server socket created on IP: '::'.

2014-10-11 13:17:21 13001 [Note] Event Scheduler: Loaded 0 events

2014-10-11 13:17:21 13001 [Note] /app/soft/mysql/bin/mysqld: ready for connections.

Version: '5.6.12-log'  socket: '/tmp/mysql.sock'  port: 3306  Source distribution

#Author :Leshami

#Blog  : http://www.linuxidc.com

3、解决故障a、通过配置my.cnf mysql选项socket文件位置解决

先停止mysql服务器[root@localhost scripts]# systemvtl restart mysqld

Shutting down MySQL.[  OK  ]

修改my.cnf,如下[root@localhost scripts]# vi /etc/my.cnf

[mysql]

no-auto-rehash

socket = /tmp/mysqld.sock  #添加该行

重启mysql服务器[root@localhost scripts]# systemctl restart mysqld

Starting MySQL..[  OK  ]

再次连接正常[root@localhost scripts]# mysql -uroot -p

Enter password:

mysql> show variables like 'version';

+---------------+------------+

| Variable_name | Value      |

+---------------+------------+

| version      | 5.6.12-log |

+---------------+------------+

b、为socket文件建立链接方式[root@SZDB mysqldata]# ln -s /tmp/mysql.sock /data/mysqldata/mysql.sock

ln: creating symbolic link `/data/mysqldata/mysql.sock' to `/tmp/mysql.sock': File exists

[root@SZDB mysqldata]# rm mysql.sock    #上面提示文件存在,所以删除之前的mysql.sock文件

[root@SZDB mysqldata]# ln -s /tmp/mysql.sock /data/mysqldata/mysql.sock

[root@SZDB mysqldata]# ls -hltr mysql.sock

lrwxrwxrwx 1 root root 15 Oct 11 14:00 mysql.sock -> /tmp/mysql.sock

[root@SZDB mysqldata]# mysql -uroot -p

Enter password:

mysql> show variables like 'socket';

+---------------+-----------------+

| Variable_name | Value          |

+---------------+-----------------+

| socket        | /tmp/mysql.sock |

+---------------+-----------------+

当您在尝试登录MySQL数据库时遇到“ERROR 1045 (28000) Access denied for user 'root'@'localhost'”错误信息,这通常表示您的MySQL服务器正在拒绝使用当前提供的用户名和密码组合登录。以下是可能导致此错误的一些常见原因及相应的解决步骤: ### 常见原因: 1. **用户名不存在**:您输入的用户名可能并不存在于MySQL的用户列表中。 2. **密码不匹配**:提供的密码与数据库中保存的密码不一致。 3. **权限设置问题**:即使用户名存在,如果其权限不足以允许登录到特定的数据库、模式或其他受限资源,则也可能导致访问被拒绝。 4. **防火墙限制**:系统或网络级别的安全配置可能会阻止某些来源的连接。 5. **MySQL服务未运行**:MySQL服务器可能已经停止运行。 6. **配置文件错误**:如`my.cnf`或`mysqld.ini`等配置文件中的设置可能阻止了正确的连接。 ### 解决步骤: #### 检查密码和用户名是否正确 1. 确认您输入的用户名和密码是否准确无误。注意区分大小写,并检查是否存在拼写错误。 - **提示**:建议使用文本编辑器直接查看数据库管理工具中存储的密码(例如,在MariaDB中,可以使用`SHOW VARIABLES LIKE 'secure_file_priv';`命令检查),确认密码是否正确。 #### 检查权限设置 1. 使用`SHOW GRANTS FOR <username>`命令查询用户的权限详细情况,确认是否具备登录所需的权限。 - **提示**:如果结果显示用户具有足够的权限,但仍无法登录,可能是其他配置错误所致。 #### 验证MySQL服务状态 1. 检查MySQL服务是否正常运行。您可以使用系统管理工具(如Windows的服务管理器或Linux的`service mysql status`)来验证服务状态。 - **提示**:确保服务已启动并且没有错信息。 #### 修改密码或创建新用户 1. 如果发现密码错误或忘记密码,可以通过`mysqladmin`命令重置密码: ```bash sudo mysqladmin -u root password new_password ``` 或者通过MySQL客户端执行SQL命令: ```sql UPDATE mysql.user SET Password=PASSWORD('new_password') WHERE User='root'; FLUSH PRIVILEGES; ``` 2. 创建新的数据库用户并授予相应权限(推荐做法): ```sql CREATE USER 'new_username'@'localhost' IDENTIFIED BY 'password'; GRANT ALL ON database_name.* TO 'new_username'@'localhost'; FLUSH PRIVILEGES; ``` #### 更新防火墙规则 1. 检查并更新系统的防火墙规则,确保它允许从本地主机(或您的预期源)连接MySQL服务。 - **提示**:在Linux环境中,可以使用`ufw`或`iptables`命令调整防火墙设置;在Windows环境下,可能需要修改Windows Defender的设置。 #### 检查MySQL配置 1. 查看`my.cnf`或`mysqld.ini`配置文件中与安全性相关的设置,如`skip-grant-tables`选项是否被激活。 - **提示**:如果在调试过程中发现`skip-grant-tables`启用,可能会影响数据库的安全性和完整性。 ### 相关问题: 1. 当在远程服务器上尝试登录时,如何处理防火墙设置? 2. 在生产环境部署时,应如何妥善管理MySQL的用户权限? 3. 当忘记MySQL管理员密码时,是否有更安全的方式来恢复密码而不影响数据安全?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值