在本周转到了考试系统的项目,开始之前就知道会遇到问题,但没想到,会遇到这么多问题。
FlywayEditionUpgradeRequiredException: Flyway Enterprise Edition or MySQL upgrade required: MySQL 5.6 is no longer supported
启动项目时遇到的第一个问题就是这样,不过这个很好解决,报错已经说得很明白了,要么升级flyway,要么升级mysql版本,毫无疑问是升级mysql版本了。
但当时为了偷懒,就用docker安装了最新版的mysql,这已经是mysql8了,这又埋下坑。
Public Key Retrieval is not allowed
新的问题出现了,这是因为MySQL8.0版本的加密方式和MySQL5.0的不一样,mysql8.0 之前的版本中加密规则是mysql_native_password,而在mysql8之后,加密规则是caching_sha2_password,最简单的解决办法就是,在连接后面加上allowPublicKeyRetrieval=true
。
关于为什么作出这个修改,官方给出了解释。
如果用户使用了 sha256_password 认证,密码在传输过程中必须使用 TLS 协议保护,但是如果 RSA 公钥不可用,可以使用服务器提供的公钥;可以在连接中通过 ServerRSAPublicKeyFile 指定服务器的 RSA 公钥,或者AllowPublicKeyRetrieval=True参数以允许客户端从服务器获取公钥;但是需要注意的是 AllowPublicKeyRetrieval=True可能会导致恶意的代理通过中间人攻击(MITM)获取到明文密码,所以默认是关闭的,必须显式开启
navicat连接不上
上面的方法确实让项目启动了,但是这样的话navicat还是无法连接的
链接不上的问题还是因为上面这个,对此我们有三个解决方案
1.将mysql用户登录的加密规则还原为mysql_native_password
ALTER USER 'test'@'%' IDENTIFIED BY '123456' PASSWORD EXPIRE NEVER;
ALTER USER 'test'@'%' IDENTIFIED WITH mysql_native_password BY '123456';
2.修改/etc/my.cnf
加入default_authentication_plugin=mysql_native_password(重启生效)
3.升级navicat版本
这个就不用多说了,navicat15是能连上的
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2)
没想到的是自己又遇到问题了,开始的时候网上看到的解决办法并不适合自己,对错暂且不论,毕竟用那种方法的好像不止一个人,所以就去下载了最新版的navicat,但是按照以前的方法连接数据库时却遇到了上面的问题,这个问题并不是第一次遇到了,但以前遇到这个都是因为mysql没启动,但这次可以肯定的是自己已经用docker启动了mysql,并且用老版navicat时,是可以连接的,所以肯定不是mysql的问题。
经过搜索找到了问题:
这是由于我们连接数据库使用的主机名参数为“localhost”,或者未使用主机名参数、服务器默认使用“localhost”做为主机名。 使用主机名参数为“localhost”连接mysql服务端时,mysql客户端会认为是连接本机,所以会尝试以socket文件方式进行连接(socket文件连接方式,比“ip:端口”方式效率更高),这时根据配置文件“/etc/mysql.cnf”的路径,未找到相应的socket文件,就会引发此错误。
所以可以猜测出,新版的navicat连接方式也变成了这样。mysql是通过docker启动的,自然本机就没有了相应的socket文件了。
关于这个问题的更多详细探索可以查看这篇文章
总结
感觉遇到这些问题某种意义都是自己作的,一切都是因为装了个最新版的mysql,但是若不是因为这次作也就无法了解到这些现在看来没什么作用的知识了,作了能够解决遇到的问题,并能了解为什么,我感觉还是值的。
参考文章
navicat连接MySQL8.0.11报2059错误的解决方案
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2)
MySQL 8.0 Public Key Retrieval is not allowed 错误的解决方法
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。