`

MYSQL版本升级到后5.0后无法连接的问题

阅读更多

最近使用的机器要迁入机房,但是安全扫描时数据库版本太低了(4.0+)必须升级数据库。于是升级到了

mysql5.6版本,升级完毕,数据迁移完毕后却发现程序怎么也连不上了,对比了密码和配置文件都没有错,后来上网查询才知道是mysql5.0以后的版本密码加密方式和以前版本不一样,要使用原来的加密方式,必须使用

OLD_PASSWORD函数设置密码。

后面为转载的解决方案,我的解决办法和这个大同小异。

错误MySQL 返回: 
#1251 - Client does not support authentication protocol requested by server; consider upgrading MySQL client

原因是因为你使用的mysql服务器版本中使用了新的密码验证机制,这需要客户端的版本要在4.0以上,原来的密码函数被改为old_password ();,这样使用password()生成的密码在旧的版本上的客户端就不好使了,而PHP中的MYSQL客户端都是3.23的(当然,mysqli的扩 展除外),问题就在这了。

目前已知解决方法:

1、进入命令行下,转到MYSQL目录的BIN目录下,进入MYSQL命令行模式:
           例:d:\mysql\bin>mysql -uroot -p123           (用户root,密码123)
2、输入命令:
           mysql>set password for 'root'@'localhost'=old_password('123');           (注意冒号不能少)
3、退入MYSQL命令行:
           mysql>\q

 

A.2.3. 客户端不支持鉴定协议

MySQL 5.1采用了基于密码混编算法的鉴定协议,它与早期客户端(4.1之前)使用的协议不兼容。如果你将服务器升级到4.1之上,用早期的客户端进行连接可能失败,并给出下述消息:

shell> mysql客户端不支持服务器请求的鉴定协议:请考虑升级MySQL客户端。

要想解决该问题,应使用下述方法之一:

·         

·         用4.1版之前的客户端连接到服务器时,请使用仍具有4.1版之前风格密码的账户。

·         对于需要使用4.1版之前的客户端的每位用户,将密码恢复为4.1版之前的风格。可以使用SET PASSWORD语句和OLD_PASSWORD()函数完成该任务:

·                mysql> SET PASSWORD FOR·                          -> 'some_user'@'some_host' = OLD_PASSWORD('newpwd');

也可以使用UPDATE和FLUSH PRIVILEGES:

mysql> UPDATE mysql.user SET Password = OLD_PASSWORD('newpwd')          -> WHERE Host = 'some_host' AND User = 'some_user';mysql> FLUSH PRIVILEGES;

用你打算使用的密码替换前例中的“newpwd”。MySQL不能告诉你原来的密码是什么,因此,你需要选择新的密码。

·         通知服务器使用旧的密码混编算法:

1.    使用“--old-passwords”选项启动mysqld

2.    对于已将密码更新为较长4.1格式的每个账户,为其指定具有旧格式的密码。可以使用下述查询确定这些账户:

3.                 mysql> SELECT Host, User, Password FROM mysql.user4.                           -> WHERE LENGTH(Password) > 16;

对于查询显示的每个账户记录,请使用Host和User值,并使用OLD_PASSWORD()函数以及SET PASSWORD或UPDATE之一指定密码,如前面所介绍的那样。

注释:在早期的PHP版本中,mysql扩展不支持MySQL 4.1.1和更高版中的鉴定协议。无论使用的PHP版本是什么,它均是正确的。如果你打算与MySQL 4.1或更高版本一起使用mysql扩展,需要使用前面介绍的选项之一,配置MySQL,以便与较早的客户端一起使用。mysqli扩展(支持“改进的MySQL”,在PHP 5中增加)与MySQL 4.1和更高版本中使用的改进的密码混编算法兼容,不需要对MySQL进行特殊配置就能使用该MySQL客户端库。关于mysqli扩展的更多信息,请参见http://php.net/mysqli

 

   首先说明一下,下面描述仅限于Win系统 其它系统我没试过,Mysql 自从4.1.1以后修改了用户密码的格式, 从16位增加到了41位, 采用了一种新的验证方法,但4.1以前的客户端协议不支持这种方法,所以造成了不能登临的后果.即使密码正确了不能正常登录,提示如下:
#1250 - Client does not support authentication protocol requested by server; consider upgrading MySQL client

在窗口中执行:
C:\mysql\bin>mysql -uroot
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 1 to server version: 5.0.0-alpha-nt

Type 'help;' or '\h' for help. Type '\c' to clear the buffer.

mysql> select password('aa');
+-------------------------------------------+
| password('aa')              |
+-------------------------------------------+
| *DEE59C300700AF9B586F9F2A702231C0AC373A13 |
+-------------------------------------------+
1 row in set (0.00 sec)

mysql>
从上可以看出password的结果返回了一个以'*'号开头的41位字符串,而以前是16位的.

Mysql官方网站给出了二种解决方法

1,使用新的客户端api,
2,强制服务器使用旧的密码方案

我首先尝试了第一种方法,从mysql5.0中拷贝libmysql.dll到php 的扩展目录中,替代了php本身附带的libmysql.dll, 但结果令人失望. Php提示装入php_mysql.dll失败:PHP Warning: PHP Startup: Unable to load dynamic library 'c:/php5/ext/php_mysql.dll' - 找不到指定的程序。后来发现新版的dll中缺少了mysql_drop_db() 这一函数 :( 只有等php或mysql出更新的dll了.

第一种方法行不通,只有试试第二种方法,mysql的官方FAQ中说,需要加上-old-password这一参数,我首先尝试 在命令行下起动mysql,
c:\mysql\bin>mysqld-nt -old-password

在另一窗口中 运行
C:\mysql\bin>mysql -uroot
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 540 to server version: 5.0.0-alpha-nt

Type 'help;' or '\h' for help. Type '\c' to clear the buffer.

mysql> select password('mypassword');
+------------------------+
| password('mypassword') |
+------------------------+
| 162eebfb6477e5d3    |
+------------------------+
1 row in set (0.55 sec)

mysql>

可以看出password的结果又变成16位的了,可喜的变化

我在c:\windows\my.ini (xp,98,中如此,2000中应在c:\wint\下)中的"mysqld"段中加入"set-variable=old-passwords"

例:
[mysqld]
basedir=C:/mysql
set-variable=old-passwords
datadir=C:/mysql/data
[WinMySQLadmin]
Server=C:/mysql/bin/mysqld-nt.exe
user=root
password=mypassword

然后在服务管理器中起动mysql

Very Good, 一切正常,

后来我又发现,只要在mysql.user表中把password的字段长度改成16系统就自动切换到了oldpassword方式,改成改回41后 又自动换到了新的验证方式.
在这里提醒一下,更改password方式后,要重新设制一下密码并刷新一下权限(或重起mysql)

、先查看 /etc/rc.d/init.d/mysqld status 看看m y s q l 是否已经启动.
另外看看是不是权限问题.

2、确定你的mysql.sock是不是在那个位置,
mysql -u 你的mysql用户名 -p -S /var/lib/mysql/mysql.sock

3、试试:service mysqld start

4、如果是权限问题,则先改变权限 #chown -R mysql:mysql /var/lib/mysql

[root@localhost ~]# /etc/init.d/mysqld start
启动 MySQL: [ 确定 ]
[root@localhost ~]# mysql -uroot -p

分享到:
评论

相关推荐

    mysql4.0和5.0驱动

    MySQL 5.0是继4.0之后的一个重大升级,于2005年发布。这个版本引入了许多新特性,如视图、触发器、存储过程的增强、分区表、外键约束等,进一步提升了数据库的性能和可扩展性。相应的,MySQL 5.0驱动也进行了更新,...

    mysql5.0参考手册-english

    - **升级建议**:建议考虑升级到较新版本的MySQL数据库。 ### MySQL 5.0 使用入门 #### 1. **平台支持** - **Linux/Unix** - 介绍如何在Linux/Unix系统上安装、配置MySQL 5.0。 - **Mac OS X** - 指导Mac OS ...

    mysql的jdbc驱动5.0

    9. **兼容性**:MySQL JDBC驱动5.0与MySQL 5.x版本数据库兼容,但可能不支持更旧或更新的MySQL版本。升级或降级数据库时需要注意兼容性问题。 10. **配置参数**:驱动连接URL中可以包含多种参数来调整连接行为,如`...

    mysql server 5.0的安装方法

    1. **操作系统兼容性**:确保您的计算机运行的是与MySQL Server 5.0兼容的操作系统版本。MySQL Server 5.0支持包括Windows在内的多种操作系统。 2. **下载安装包**:访问MySQL官方网站或其他可信来源下载MySQL ...

    MySQL GUI Tools 5.0 rar

    MySQL GUI Tools 5.0 是一组强大的图形用户界面工具,专为MySQL数据库管理系统设计,旨在帮助用户更方便、高效地管理和操作MySQL数据库。这个版本的工具集提供了多种功能,包括数据库设计、数据可视化、备份、恢复、...

    MySql5.0安装程序

    在使用MySQL5.0时,用户还需要了解如何备份和恢复数据、进行性能优化、处理错误和日志、以及如何升级到更高版本。同时,熟悉SQL语言基础,如SELECT、INSERT、UPDATE和DELETE等操作,是操作MySQL的基本技能。 总之,...

    MySql 5.0+ JDBC驱动

    9. **版本兼容**:`mysql-connector-java-5.0.8`适用于MySQL 5.0及更高版本,但请注意,不同版本的驱动可能与特定的MySQL版本存在兼容性问题,升级或降级数据库时需检查驱动版本。 10. **新特性**:在MySQL 5.0版本...

    mysql5.0.75tar.gz

    MySQL 5.0.75 是 MySQL 数据库管理系统的一个旧版本,发布于2008年,属于 MySQL 5.0 系列的一部分。MySQL 5.0 是一个重要的里程碑,因为它引入了许多新特性和改进,同时保持了与早期版本的良好兼容性。以下是关于 ...

    MySql5.0工具

    MySQL 5.0是MySQL数据库管理系统的一个重要版本,它在2005年发布,带来了许多新特性和改进。MySQL是一种流行的开源关系型数据库管理系统(RDBMS),因其高效、可靠且易于使用而广受开发者喜爱。以下是关于MySQL 5.0...

    mysql5.0安装包+安装步骤文档

    MySQL 5.0是数据库管理系统领域中非常经典的一个版本,它是开源、免费的,并且广泛应用于网站开发、数据存储和管理。在这个安装包中,包含了MySQL 5.0的安装程序以及详细的安装步骤文档,这对于那些需要搭建数据库...

    mysql-connector-odbc-3.51.26-win32支持MYSQL5.0以上版本

    这意味着即使您的MySQL服务器升级到5.0或更高版本,此驱动仍然能够正常工作,提供数据访问功能。早期版本的MySQL Connector/ODBC可能不兼容这些新版本,因此选择合适版本的驱动对于确保应用程序与数据库的兼容性至关...

    mysql-gui-tools-5.0-r17-win32

    MySQL GUI Tools 5.0 r17 是一套用于Windows操作系统的数据库管理工具,它提供了图形化...然而,随着MySQL的发展,后续的版本可能包含了更多的功能和优化,因此在实际使用中,应考虑升级到更现代的工具以获取最佳体验。

    mysql5.0和5.1的jar包.zip

    随着MySQL版本的更新,驱动程序也会随之改进,提供更好的性能和更多的特性。在选择使用哪个版本时,应确保与正在使用的MySQL服务器版本相匹配,以确保最佳的兼容性和性能。同时,开发者应始终关注安全更新,及时升级...

    mysql5.0安装教程(图文详解).pdf

    - **版本升级路径**:概述从MySQL 5.0升级到更高版本的推荐路径和可能遇到的兼容性问题。 ### 结语 本文汇总的知识点包括了MySQL 5.0数据库安装前的准备、安装过程、配置、操作、故障排查、性能优化以及版本升级等...

    mysql5.0数据库安装资料

    MySQL 5.0是MySQL数据库管理系统的一个重要版本,它在2005年发布,带来了许多新特性,改进了性能和稳定性。以下是关于MySQL 5.0安装过程及相关知识点的详细说明: 一、MySQL 5.0概述 MySQL 5.0是开源的关系型数据库...

    apache2.2+php5.2+MYSQL5.0+phpMyAdmin2.9+Zend 配置文档

    在实际操作中,可能还会遇到如依赖冲突、版本兼容性等问题,这些问题需要根据具体情况进行解决。此外,随着技术的发展,更现代的版本(如Apache2.4、PHP7.x、MySQL8.0等)可能提供更好的性能和安全性,因此适时升级...

    mysql5.0安装截图

    - **更新与维护**:虽然MySQL 5.0曾经非常流行,但现在已经是过时版本,可能存在安全漏洞,建议升级到最新版本以获取更好的功能、性能以及安全性保障。 - **兼容性**:考虑到软件版本的兼容性问题,在安装过程中应...

    mysql8和mysql5的连接驱动jar包

    MySQL是世界上最受欢迎的开源关系型数据库管理系统之一,其在各个版本间不断进行更新与优化以满足不断变化的用户需求。本篇文章将详细讨论MySQL8与MySQL5在连接驱动jar包方面的差异,以及如何使用这些驱动来连接Java...

    mysql 5.0_18的安装详解

    MySQL 5.0_18 是一款经典的数据库管理系统,它在当时提供了稳定性和高效的数据处理能力。本篇文章将详细介绍如何在Windows环境下安装...同时,随着MySQL版本的迭代,建议及时升级到更高版本以获取更多新特性和优化。

    MySql+数据库+5.0.22+for+Win.msi

    4. 安装完成后的验证:安装完成后,可以通过命令行或图形化工具连接到MySQL服务器,确认安装成功并能正常运行。 在标签中,"mysql安装包"明确指出了这个文件的主要用途。在压缩包子文件的文件名称列表中,只有...

Global site tag (gtag.js) - Google Analytics