凯发娱发k8

怎样用springboot 排除数据库启动方式 -凯发娱发k8

2024-01-18

本篇文章为大家展示了怎样用springboot 排除数据库启动方式,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

springboot 排除数据库启动

1. 场景

在家里运行项目,运行springboot的时候报数据库连接不了,公司的数据库家里不能连接。

2. 配置

2.1 保留之前的properties 配置,不删除;

2.2 在启动类中添加

exclude = {datasourceautoconfiguration.class}
package cn.cncommdata.file;
import org.mybatis.spring.annotation.mapperscan;
import org.springframework.boot.springapplication;
import org.springframework.boot.autoconfigure.springbootapplication;
import org.springframework.boot.autoconfigure.jdbc.datasourceautoconfiguration;
import org.springframework.cloud.openfeign.enablefeignclients;
/**
 * 启动类
 */
@springbootapplication(scanbasepackages = "cn.cncommdata", exclude = {datasourceautoconfiguration.class})
@enablefeignclients(basepackages = {"cn.cncommdata", "cc.iooc"})
@mapperscan("cn.cncommdata.file.dao")
public class fileapplication {
    /**
     * main
     *
     * @param args args
     */
    public static void main(string[] args) {
        springapplication.run(fileapplication.class, args);
    }
    /**
     * 没什么用,就是不想让checkstyle报错
     */
    public void init() {
    }
}

springboot不经过数据库直接启动

问题

之前开发工程中,有一个单独注册在nacos上服务的项目(不需要访问数据库)需要启动,但是启动会报错。

错误

exception encountered during context initialization - cancelling refresh attempt: org.springframework.beans.factory.beancreationexception: error creating bean with name ‘datasource' defined in class path resource [org/springframework/boot/autoconfigure/jdbc/datasourceconfiguration$hikari.class]: bean instantiation via factory method failed; nested exception is org.springframework.beans.beaninstantiationexception: failed to instantiate [com.zaxxer.hikari.hikaridatasource]: factory method ‘datasource' threw exception; nested exception is org.springframework.boot.autoconfigure.jdbc.datasourcepropertiesdatasourcebeancreationexception: failed to determine a suitable driver class

原因

springboot项目默认会访问数据库,因为此时没有写数据库连接,所以出现这个错误。

解决

在启动类上加上一个注解,在容器加载的时候默认排除数据库连接即可。

具体如图所示:

上述内容就是怎样用springboot 排除数据库启动方式,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注本站行业资讯频道。

网站地图