百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

MySQL 客户端连不上(1045 错误)原因全解析-爱可生

nanshan 2024-10-11 13:33 10 浏览 0 评论


在我们学习 MySQL 或从事 MySQL DBA 工作期间,时常会遇到:“我尝试连接到 MySQL 并且收到1045 错误,但我确定我的用户和密码都没问题”。

不管你现在是否是高手还是高高手,都不可避免曾经在初学的时候犯过一些很初级的错误,例如:用户名密码都填错了。而且工作一段时间后也偶尔会遇到一些不常见错误原因。


一、连接错误的主机

[root@localhost ~]# mysql -u root -p123456mysql: [Warning] Using a password on the command line interface can be insecure.ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)

如果未指定要连接的主机(使用 -h 标志),则 MySQL 客户端将尝试连接到 localhost 实例,同时您可能尝试连接到另一个主机端口实例。

修复:仔细检查您是否尝试连接到 localhost,或者确保指定主机和端口(如果它不是 localhost):

[root@localhost ~]# mysql -u root -p123456 -h <IP> -P 3306


二、用户不存在

[root@localhost ~]# mysql -u nonexistant -p123456 -h localhostmysql: [Warning] Using a password on the command line interface can be insecure.ERROR 1045 (28000): Access denied for user 'nonexistant'@'localhost' (using password: YES)

修复:仔细检查用户是否存在:

mysql> SELECT User FROM mysql.user WHERE User='nonexistant';Empty set (0.00 sec)

如果用户不存在,请创建一个新用户:

mysql> CREATE USER 'nonexistant'@'localhost' IDENTIFIED BY 'sekret';Query OK, 0 rows affected (0.00 sec)mysql> FLUSH PRIVILEGES;Query OK, 0 rows affected (0.01 sec)


三、用户存在但客户端主机无权连接

[root@localhost ~]# mysql -u nonexistant -p123456mysql: [Warning] Using a password on the command line interface can be insecure.ERROR 1045 (28000): Access denied for user 'nonexistant'@'localhost' (using password: YES)

修复:您可以通过以下查询检查 MySQL 允许连接的主机用户/主机:

mysql> SELECT Host, User FROM mysql.user WHERE User='nonexistant';+-------------+-------------+| Host        | User        |+-------------+-------------+| 192.168.0.1 | nonexistant |+-------------+-------------+1 row in set (0.00 sec)

如果需要检查客户端连接的 IP,可以使用以下 Linux 命令来获取服务器 IP:

[root@localhost ~]# ip address | grep inet | grep -v inet6    inet 127.0.0.1/8 scope host lo    inet 192.168.0.20/24 brd 192.168.0.255 scope global dynamic wlp58s0

或公共IP:

[root@localhost ~]# dig +short myip.opendns.com @resolver1.opendns.com177.128.214.181

然后,您可以创建具有正确主机(客户端 IP)的用户,或使用'%'(通配符)来匹配任何可能的 IP:

mysql> CREATE USER 'nonexistant'@'%' IDENTIFIED BY '123456';Query OK, 0 rows affected (0.00 sec)


四、密码错误,或者用户忘记密码

mysql> CREATE USER 'nonexistant'@'%' IDENTIFIED BY '123456';Query OK, 0 rows affected (0.00 sec)

修复:检查和/或重置密码:

您无法从 MySQL 以纯文本格式读取用户密码,因为密码哈希用于身份验证,但您可以将哈希字符串与“PASSWORD”函数进行比较:

mysql> SELECT Host, User, authentication_string, PASSWORD('forgotten') FROM mysql.user WHERE User='nonexistant';+-------------+-------------+-------------------------------------------+-------------------------------------------+| Host        | User        | authentication_string                     | PASSWORD('forgotten')                     |+-------------+-------------+-------------------------------------------+-------------------------------------------+| 192.168.0.1 | nonexistant | *AF9E01EA8519CE58E3739F4034EFD3D6B4CA6324 | *70F9DD10B4688C7F12E8ED6C26C6ABBD9D9C7A41 || %           | nonexistant | *AF9E01EA8519CE58E3739F4034EFD3D6B4CA6324 | *70F9DD10B4688C7F12E8ED6C26C6ABBD9D9C7A41 |+-------------+-------------+-------------------------------------------+-------------------------------------------+2 rows in set, 1 warning (0.00 sec)

我们可以看到 PASSWORD('forgotten')哈希与 authentication_string 列不匹配,这意味着 password string ='forgotten' 不是正确的登录密码。

如果您需要覆盖密码,可以执行以下查询:

mysql> set password for 'nonexistant'@'%' = 'hello$!world';Empty set (0.00 sec)



五、Bash 转换密码中的特殊字符

[root@localhost ~]# mysql -u nonexistant -phello$!worldmysql: [Warning] Using a password on the command line interface can be insecure.ERROR 1045 (28000): Access denied for user 'nonexistant'@'localhost' (using password: YES)

修复:通过在单引号中包装密码来防止 bash 解释特殊字符:

[root@localhost ~]# mysql -u nonexistant -p'hello$!world'mysql: [Warning] Using a password on the command line interface can be insecure...mysql>


六、SSL 是必须的,但客户没有使用

mysql> create user 'ssluser'@'%' identified by '123456';Query OK, 0 rows affected (0.00 sec)mysql> alter user 'ssluser'@'%' require ssl;Query OK, 0 rows affected (0.00 sec)...[root@localhost ~]# mysql -u ssluser -p123456mysql: [Warning] Using a password on the command line interface can be insecure.ERROR 1045 (28000): Access denied for user 'ssluser'@'localhost' (using password: YES)

修复:添加 -ssl-mode 标志(-ssl 标志已弃用但也可以使用)

[https://dev.mysql.com/doc/relnotes/mysql/5.7/en/news-5-7-11.html]

[root@localhost ~]# mysql -u ssluser -p123456 --ssl-mode=REQUIRED...mysql>

最后,如果您真的被锁定并需要绕过身份验证机制以重新获得对数据库的访问权限,请执行以下几个简单步骤:

  1. 停止实例
  2. 编辑 my.cnf 并在 [mysqld] 下添加 skip-grant-tables(这样可以在不提示输入密码的情况下访问 MySQL)。在 MySQL 8.0 上,跳过网络是自动启用的(只允许从 localhost 访问 MySQL),但对于以前的 MySQL 版本,建议在 [mysqld] 下添加 -skip-networking
  3. 启动实例
  4. 使用 root 用户访问(mysql -uroot -hlocalhost);
  5. 发出必要的 GRANT / CREATE USER / SET PASSWORD 以纠正问题(可能设置一个已知的 root 密码将是正确的事情:SET PASSWORD FOR 'root'@'localhost'='S0vrySekr3t'
  6. 停止实例
  7. 编辑 my.cnf 并删除 skip-grant-tables 和 skip-networking
  8. 再次启动 MySQL
  9. 您应该能够使用 roothost 从 root 用户登录,并对 root 用户执行任何其他必要的纠正操作。

本文按常见到复杂的顺序将可能报 1045 的错误原因全部列举出来,看完了还不赶快收藏!

相关推荐

ssh终端xshell日志查看命令(xshell怎么看日志)

现在我们云服务器运维较多用的是SSH工具,其中常用的包括PUTTY、XSHELL等,其实大同小异界面UI稍微不同,但是都可以进入远程连接。这里有朋友提到如何查看服务器的日志文件,这个其实和是否使用XS...

使用 Fail Ban 日志分析 SSH 攻击行为

通过分析`fail2ban`日志可以识别和应对SSH暴力破解等攻击行为。以下是详细的操作流程和关键分析方法:---###**一、Fail2ban日志位置**Fail2ban的日志路径因系统配置...

如何高效读取Linux日志文件?这些命令要熟记于心!

在Linux系统中,日志文件通常存储在/var/log目录下。比如,/var/log/syslog(或/var/log/messages,视发行版而定)记录系统整体事件,/var/log/a...

Windows服务器远程登录日志查询方法,linux查看登录日志方法

概述本文介绍Windows、Linux服务器查询系统的远程登录日志方法。根据服务器所使用的操作系统不同,有以下两种查询方法。Linux操作系统的登录日志查询通过远程连接登录Linux服务器,使用roo...

iptables防火墙如何记录日志(防火墙日志查看)

例如:记录所有ssh服务的登录的日志首先,我们需要了解如何将所有的iptables的INPUT链数据包记录到/var/log/messages中。如果你已经有一些iptables规则了,那么将记录日志...

如何安全管理SSH密钥以防止服务器被入侵

SSH密钥安全管理实施指南(2025年更新版)一、密钥生成与存储规范高强度密钥生成bashCopyCodessh-keygen-ted25519-a100#生成ED25519算法密钥(比...

在CentOS上安装nginx服务器(centos搭建代理服务器)

一、环境描述1.虚拟机配置CPU:单核内存:2GB硬盘:120GBIP:10.24.17.1082.操作系统版本:CentOS6.6x86_64安装方式:Minimal3.虚拟化环境VM...

CentOS7安全加固的一份整理规划建议

◆更新系统:及时更新CentOS7操作系统版本和安全补丁,确保系统以最新状态运行。◆关闭不必要的服务:在运行系统时,应关闭不需要的服务和端口,以减少系统暴露的攻击面。◆安装防火墙:使用iptables...

第四十七天-二叉树,centOS安装tomcat,Maven,vsftpd

学习笔记:1.Maven是Apache下的一个纯Java开发的开源项目。基于项目对象模型(缩写:POM)概念,Maven利用一个中央信息片断能管理一个项目的构建、报告和文档等步骤。Maven...

Linux远程桌面连接使用教程 Widows终端远程连接Linux服务器

一、前言为什么不是远程连接Linux服务器?因为我不会,远程连接window我就用电脑自带的“远程桌面连接”。以下所述都是在CentOS操作系统下的。服务器刚换成Linux的时候很迷茫,感觉无从下手...

CentOS 安全加固操作,保护你的操作系统

系统加固是保障系统安全的重要手段,对于维护企业数据安全、用户隐私以及系统稳定运行具有重要意义。加固后的系统更加健壮和稳定,能够有效减少因安全问题导致的系统故障和停机时间,提高系统的可用性和可靠性。通过...

Dockerfile部署Java项目(docker如何部署java项目)

1、概述本文主要会简单介绍什么是Docker,什么是Dockerfile,如何安装Docker,Dockerfile如何编写,如何通过Dockerfile安装jar包并外置yaml文件以及如何通过do...

CentOS7云主机部署Fail2ban阻断SSH暴力破解

关于Fail2banFail2ban可以监视你的系统日志,然后匹配日志的错误信息(正则式匹配)执行相应的屏蔽动作(一般情况下是调用防火墙屏蔽)例如:当有人在试探你的HTTP、SSH、SMTP、FTP密...

在CentOS7上用源码编译安装PostgreSQL

1、新建postgres用户#useraddpostgres&&passwdpostgres2、安装依赖包#yum-yinstallmakegccgcc-c++readline...

pure-ftpd 使用(ftp prompt命令)

pure-ftpd是一个免费的ftp软件,其他介绍就不多说了。我们直接开始主题安装centosyuminstallepel-releaseyuminstallpure-ftpd配置备份原配置...

取消回复欢迎 发表评论: