美文网首页我爱编程
SpringBoot 2.0 系列(三):流程详解(下)

SpringBoot 2.0 系列(三):流程详解(下)

作者: ViYoung | 来源:发表于2018-06-11 06:45 被阅读0次

    自动配置

    Spring Boot自动配置尝试根据添加的jar依赖项自动配置Spring应用程序。例如,如果HSQLDB在我们的类路径上,并且我们没有手动配置任何数据库连接bean,那么Spring Boot将自动配置内存中的数据库。
    我们如果需要选择加入到自动配置可以通过将@EnableAutoConfiguration@SpringBootApplication注释添加到我们的@Configuration类中。

    我们应该只添加一个@SpringBootApplication@EnableAutoConfiguration注释。我们通常建议只将一个或另一个添加到 @Configuration 主类中。

    自定义自动配置

    自动配置具有良好的非侵入性。在任何时候,我们都可以开始定义自己的配置,以替换自动配置的特定部分。例如,如果我们添加自己的数据源bean,默认的嵌入式数据库支持就会退居幕后,而采用我们所配置的数据源bean。
    如果我们需要了解当前正在应用的自动配置,以及为什么要使用这些配置,可以使用--debug开关启动应用程序。这样做可以为核心日志记录器的选择提供调试日志,并将条件报告记录到控制台。

    禁用特定类的自动配置

    如果我们发现我们不希望的特定自动配置类被应用,我们可以使用@EnableAutoConfiguration的排除属性来禁用它们,如下面的示例所示:

    import org.springframework.boot.autoconfigure.*;
    import org.springframework.boot.autoconfigure.jdbc.*;
    import org.springframework.context.annotation.*;
    
    @Configuration
    @EnableAutoConfiguration(exclude={DataSourceAutoConfiguration.class})
    public class MyConfiguration {
    }
    

    如果类不在类路径上,则可以使用注释的 excludeName 属性并指定完全限定的名称。最后,我们还可以通过使用spring.autoconfigure.exclude排除属性来控制自动配置类的列表。

    我们可以在注释级别和通过使用属性定义排除。

    Spring bean和依赖项注入

    我们可以自由地使用任何标准Spring框架技术来定义bean及其注入的依赖项。为了简单起见,我们经常发现使用@ComponentScan(查找bean)和使用@Autowired(进行构造函数注入)非常有效。
    如果我们按照上面的建议构造代码(将应用程序类定位到根包中),我们可以添加@ComponentScan,而不需要任何参数。所有应用程序组件(@Component, @Service, @Repository, @Controller等)都自动注册为Spring bean。
    下面的示例显示了一个@Service Bean:

    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.stereotype.Service;
    
    @Service
    public class DatabaseAccountService implements AccountService {
    
        private final RiskAssessor riskAssessor;
    
        @Autowired
        public DatabaseAccountService(RiskAssessor riskAssessor) {
            this.riskAssessor = riskAssessor;
        }
    
        // ...
    
    }
    

    如果一个bean有一个构造函数,可以省略@Autowired,如下面的示例所示:

    @Service
    public class DatabaseAccountService implements AccountService {
    
        private final RiskAssessor riskAssessor;
    
        public DatabaseAccountService(RiskAssessor riskAssessor) {
            this.riskAssessor = riskAssessor;
        }
    
        // ...
    
    }
    

    注意:如何使用构造函数注入让riskAssessor字段被标记为final,表明它不能随后更改。

    使用@SpringBootApplication注解

    许多Spring Boot开发人员喜欢他们的应用程序使用自动配置、组件扫描并能够在“application class”上定义额外的配置。可以使用一个@SpringBootApplication注释来启用这三个特性,即:
    @EnableAutoConfiguration:启用Spring Boot的自动配置机制
    @ComponentScan:在应用程序所在的包上启用@Component扫描
    @Configuration:允许在上下文中注册额外的bean或导入额外的配置类
    @SpringBootApplication注释相当于使用@Configuration@EnableAutoConfiguration@ComponentScan的默认属性,如下面的示例所示:

    import org.springframework.boot.SpringApplication;
    import org.springframework.boot.autoconfigure.SpringBootApplication;
    
    @SpringBootApplication // same as @Configuration @EnableAutoConfiguration @ComponentScan
    public class Application {
    
        public static void main(String[] args) {
            SpringApplication.run(Application.class, args);
        }
    
    }
    

    @SpringBootApplication还提供别名来定制@EnableAutoConfiguration@ComponentScan的属性。

    这些特性中没有一个是强制性的,我们可以选择使用它支持的任何特性来替换这个单一注释。例如,我们可能不想在应用程序中使用组件扫描:

    
    import org.springframework.boot.SpringApplication;
    import org.springframework.context.annotation.ComponentScan
    import org.springframework.context.annotation.Configuration;
    import org.springframework.context.annotation.Import;
    
    @Configuration
    @EnableAutoConfiguration
    @Import({ MyConfig.class, MyAnotherConfig.class })
    public class Application {
    
        public static void main(String[] args) {
                SpringApplication.run(Application.class, args);
        }
    
    }
    

    在本例中,应用程序与任何其他Spring Boot应用程序一样,只是不会自动检测到@component - anno类,并且显式地导入用户定义的bean(根据@Import)。

    运行你的应用

    将应用程序打包为jar并使用嵌入式HTTP服务器的最大好处之一是,可以像运行其他应用程序一样运行应用程序。调试SpringBoot应用程序也很容易。我们不需要任何特殊的IDE插件或扩展。

    本节只讨论基于jar的打包。如果我们选择将应用程序打包为war文件,我们应该参考服务器和IDE文档。

    通过IDE启动

    我们可以将IDE中的SpringBoot应用程序作为一个简单的Java应用程序运行。但是,我们首先需要导入项目。导入步骤取决于我们的IDE和构建系统。大多数ide都可以直接导入Maven项目。
    如果我们不能直接将项目导入IDE,那么我们可以使用build插件生成IDE元数据。Maven包含Eclipse和IDEA的插件。Gradle提供各种ide的插件。

    如果我们不小心运行了两次web应用程序,我们会看到一个“已经使用的端口”错误。STS用户可以使用Relaunch按钮而不是Run按钮来确保关闭任何现有实例。

    作为打包的应用程序运行

    如果我们使用Spring Boot Maven或Gradle插件来创建可执行jar,我们可以使用java -jar来运行应用程序,如下例所示:

    $ java -jar target/myapplication-0.0.1-SNAPSHOT.jar
    

    还可以运行支持远程调试的打包应用程序。这样做可以将调试器附加到打包的应用程序中,如下例所示:

    $ java -Xdebug -Xrunjdwp:server=y,transport=dt_socket,address=8000,suspend=n \
           -jar target/myapplication-0.0.1-SNAPSHOT.jar
    
    使用Maven插件

    Spring Boot Maven插件包含一个可以用来快速编译和运行应用程序的运行目标。应用程序迅速运行,就像它们在IDE中一样。下面的示例显示了运行Spring引导应用程序的典型Maven命令:

    $ mvn spring-boot:run
    

    我们可能还想使用MAVEN_OPTS操作系统环境变量,如下面的示例所示:

    $ export MAVEN_OPTS=-Xmx1024m
    
    使用Gradle插件

    Spring Boot Gradle插件还包含一个bootRun任务,该任务可用于迅速运行应用程序。每当应用org.springframework时,都会添加bootRun任务。引导和java插件,如下例所示:

    $ gradle bootRun
    
    

    我们可能还想使用JAVA_OPTS操作系统环境变量,如下例所示:

    $ export JAVA_OPTS=-Xmx1024m
    

    下节预告:

    详细介绍基于Spring Boot的热加载~

    相关文章

      网友评论

        本文标题:SpringBoot 2.0 系列(三):流程详解(下)

        本文链接:https://www.haomeiwen.com/subject/bdlceftx.html