浅谈mysql8.0新特性的坑和解决办法(小结)

前言

一、创建用户和授权

mysql模块是一个开源的、JavaScript编写的MySQL驱动,可以在Node.js应用中来操作MySQL。但在使用过程中,出现了“ER_NOT_SUPPORTED_AUTH_MODE”问题。

在mysql8.0创建用户和授权和之前不太一样了,其实严格上来讲,也不能说是不一样,只能说是更严格,mysql8.0需要先创建用户和设置密码,然后才能授权。

本文介绍了出现该问题的原因及解决方案。

#先创建一个用户create user 'hong'@'%' identified by '123123';#再进行授权grant all privileges on *.* to 'hong'@'%' with grant option;

报错信息

如果还是用原来5.7的那种方式,会报错误:

当我试图使用mysql模块来连接MySQL 8时,出现了如下错误信息:

grantallprivilegeson*.*to'sroot'@'%'identifiedby'123123';

ERROR1064(42000):YouhaveanerrorinyourSQLsyntax;checkthemanualthatcorrespondsto yourMySQLserverversionfortherightsyntaxtousenear'identifiedby'123123''atline1

D:workspaceGithubnodejs-book-samplessamplesmysql-demoindex.js:17throw error;^Error: ER_NOT_SUPPORTED_AUTH_MODE: Client does not support authentication protocol requested by server; consider upgrading MySQL clientat Handshake.Sequence._packetToError (D:workspaceGithubnodejs-book-samplessamplesmysql-demonode_modulesmysqllibprotocolsequencesSequence.js:47:14)at Handshake.ErrorPacket (D:workspaceGithubnodejs-book-samplessamplesmysql-demonode_modulesmysqllibprotocolsequencesHandshake.js:123:18)at Protocol._parsePacket (D:workspaceGithubnodejs-book-samplessamplesmysql-demonode_modulesmysqllibprotocolProtocol.js:291:23)at Parser._parsePacket (D:workspaceGithubnodejs-book-samplessamplesmysql-demonode_modulesmysqllibprotocolParser.js:433:10)at Parser.write (D:workspaceGithubnodejs-book-samplessamplesmysql-demonode_modulesmysqllibprotocolParser.js:43:10)at Protocol.write (D:workspaceGithubnodejs-book-samplessamplesmysql-demonode_modulesmysqllibprotocolProtocol.js:38:16)at Socket.anonymous (D:workspaceGithubnodejs-book-samplessamplesmysql-demonode_modulesmysqllibConnection.js:91:28)at Socket.anonymous (D:workspaceGithubnodejs-book-samplessamplesmysql-demonode_modulesmysqllibConnection.js:525:10)at Socket.emit (events.js:196:13)at addChunk (_stream_readable.js:290:12)--------------------at Protocol._enqueue (D:workspaceGithubnodejs-book-samplessamplesmysql-demonode_modulesmysqllibprotocolProtocol.js:144:48)at Protocol.handshake (D:workspaceGithubnodejs-book-samplessamplesmysql-demonode_modulesmysqllibprotocolProtocol.js:51:23)at Connection.connect (D:workspaceGithubnodejs-book-samplessamplesmysql-demonode_modulesmysqllibConnection.js:119:18)at Object.anonymous (D:workspaceGithubnodejs-book-samplessamplesmysql-demoindex.js:12:12)at Module._compile (internal/modules/cjs/loader.js:759:30)at Object.Module._extensions..js (internal/modules/cjs/loader.js:770:10)at Module.load (internal/modules/cjs/loader.js:628:32)at Function.Module._load (internal/modules/cjs/loader.js:555:12)at Function.Module.runMain (internal/modules/cjs/loader.js:826:10)at internal/main/run_main_module.js:17:11

二、MySQL8.0 的远程链接

出错原因

MySQL8.0 安装完成后出现无法远程链接的现象,这是因为MySQL8.0只支持 localhost 访问,我们必须设置一下才可以远程访问。

导致这个错误的原因是,目前,最新的mysql模块并未完全支持MySQL 8的“caching_sha2_password”加密方式,而“caching_sha2_password”在MySQL 8中是默认的加密方式。因此,下面的方式命令是默认已经使用了“caching_sha2_password”加密方式,该账号、密码无法在mysql模块中使用。

具体设置步骤如下:

mysql ALTER USER 'root'@'localhost' IDENTIFIED BY '123456';Query OK, 0 rows affected (0.12 sec)

① 登录MySQL

解决方法

执行命令为:mysql -u root -p

解决方法是从新修改用户root的密码,并指定mysql模块能够支持的加密方式:

回车后输入密码

mysql ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '123456';Query OK, 0 rows affected (0.12 sec)

② 选择 mysql 数据库

上述语句,显示指定了使用“mysql_native_password”的加密方式。这种方式是在mysql模块能够支持。

执行命令为:use mysql;

再此运行应用,可以看到如下的控制台输出信息:

查看mysql 数据库中存储的用户信息的 user 表。

$ node index.jsThe result is: RowDataPacket { user_id: 1, username: '老卫' }

③查看mysql 数据库的 user 表中当前 root 用户的相关信息

其中,“RowDataPacket { user_id: 1, username: ‘老卫' }”就是数据库查询的结果。

执行命令为:select host,user,authentication_string,plugin from user;

本文由美高梅官方网站发布于数据统计,转载请注明出处:浅谈mysql8.0新特性的坑和解决办法(小结)

TAG标签:
Ctrl+D 将本页面保存为书签,全面了解最新资讯,方便快捷。