介绍
项目使用IDEA开发,然后打成war包并且传到ubuntu服务器后发现页面能够正常打开,只要涉及到数据库的时候页面就会卡死,然后执行了以下操作后项目恢复
查看Tomcat日志
1、先切换到tomcat目录下的logs目录
2、查看日志文件 tail -f catalina.out
注意:Ctrl+c 是退出tail命令。
发现大概报了这么一个错(当时没有复制,大概这么个意思):
错误:1251 SQLSTATE: 08004 (ER_NOT_SUPPORTED_AUTH_MODE) 消息:客户端不支持服务
经过查阅资料以后得知这是JDBC驱动和MySQL版本不匹配导致的,然后下载了8.0.19版本的驱动。
更新驱动
1.引用外部库 mysql-connector-java-8.0.19版本的jar
2.修改jdbc驱动类:com.mysql.jdbc.Driver 改成 com.mysql.cj.jdbc.Driver
3.修改jdbcUrl:jdbc:mysql://{ip}:{port}/{db}?characterEncoding=utf8&useSSL=false&serverTimezone=UTC&rewriteBatchedStatements=true
更新完成了以后重新上传服务器,发现还是操作不了,查看日志以后发现错误变成了:
04-May-2020 21:32:28.632 SEVERE [Druid-ConnectionPool-Create-1453095229] com.alibaba.druid.support.logging.JakartaCommonsLoggingImpl.error create connection SQLException, url: jdbc:mysql://127.0.0.1:3306/urlchange?characterEncoding=utf8&useSSL=false&serverTimezone=UTC&rewriteBatchedStatements=true, errorCode 1698, state 28000
查资料得知该错误是因为root的plugin被修改成了auth_socket引起的
修改数据库
查看一下user表,错误的起因就是在这里, root的plugin被修改成了auth_socket,用密码登陆的plugin应该是mysql_native_password。
mysql> select user, plugin from mysql.user;
+-----------+-----------------------+
| user | plugin |
+-----------+-----------------------+
| root | auth_socket |
| mysql.sys | mysql_native_password |
| dev | mysql_native_password |
+-----------+-----------------------+
3 rows in set (0.01 sec)
然后对root的plugin进行更新
update mysql.user set plugin='mysql_native_password' where user='root';
然后重启MySQL,问题解决
sudo service mysql stop
sudo service mysql start