Spingboot连Mysql出错:Cause:java.sql.SQLException: Access denied for user ‘root‘@‘hadoop100‘ (using pass

报错代码如下 : 

Caused by: org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.apache.ibatis.session.SqlSessionFactory]: Factory method 'sqlSessionFactory' threw exception; nested exception is com.baomidou.mybatisplus.core.exceptions.MybatisPlusException: Error: GlobalConfigUtils setMetaData Fail !  Cause:java.sql.SQLException: Access denied for user 'root'@'hadoop100' (using password: YES)

datasource配置

 

尝试解决方案: 

1.修改properties文件配置、检查账号密码

2.修改mysql的my.cnf文件配置

3.在mysql中加用户授权

正确解决方案

在进行上述操作后无果,后来看到CDSN中这位哥的文章,尝试了一下找mysql用户匹配的问题:

首先找到自己use表所在的database,然后使用下面sql查出用户的匹配信息:

select host,user,password from user;

我在配置文件中用的用户是user是root,host是hadoop100,在以往的脑回路里面我认为只要是root用户,直接登录mysql的密码都是123456就完事了,在yml配置也一样,但是其实对应不同的host,root用户的密码都不一样。上图可以看到hadoop100的密码为空,而我datasource配置的是123456,mysql肯定拒绝访问。故改为如下:

保存后再次尝试问题已经解决! 

 


版权声明:本文为weixin_43820544原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。