记录一次JavaWeb项目在Ubuntu服务器上部署失败的问题

介绍

项目使用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
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值