0
点赞
收藏
分享

微信扫一扫

spring boot 2高级篇(1)——Spring Boot应用

spring boot 2高级篇(1)——Spring Boot应用_spring

本章节将回答一些常见的"我该怎么做"类型的问题,这些问题在我们使用Spring Boot时经常遇到。这虽然不是一个详尽的列表,但它覆盖了很多方面。

如果遇到一个特殊的我们没有覆盖的问题,你可以查看stackoverflow.com,看是否已经有人给出了答案;这也是一个很好的提新问题的地方(请使用​​spring-boot​​标签)。

Spring Boot应用

创建自己的FailureAnalyzer

FailureAnalyzer是拦截启动时的异常并将它转换为可读消息的很好方式,Spring Boot为应用上下文相关异常, JSR-303校验等提供分析器,实际上创建你自己的分析器也相当简单。

​AbstractFailureAnalyzer​​​是​​FailureAnalyzer​​​的一个方便扩展,根据指定类型的异常是否出现来进行处理。你可以继承它,这样就可以处理实际出现的异常。如果出于某些原因,不能处理该异常,那就返回​​null​​让其他实现处理。

​FailureAnalyzer​​​的实现需要注册到​​META-INF/spring.factories​​​,以下注册了​​ProjectConstraintViolationFailureAnalyzer​​:

org.springframework.boot.diagnostics.FailureAnalyzer=\
com.example.ProjectConstraintViolationFailureAnalyzer

解决自动配置问题

Spring Boot自动配置总是尝试尽最大努力去做正确的事,但有时候会失败并且很难说出失败原因。

在每个Spring Boot ​​ApplicationContext​​​中都存在一个相当有用的​​ConditionEvaluationReport​​​。如果开启​​DEBUG​​​日志输出,你将会看到它。如果你使用​​spring-boot-actuator​​​,则会有一个​​autoconfig​​的端点,它将以JSON形式渲染该报告。你还可以使用它调试应用程序,并能查看Spring Boot运行时都添加了哪些特性(及哪些没添加)。

通过查看源码和javadoc可以获取更多问题的答案,以下是一些经验:

  • 查找名为​​*AutoConfiguration​​的类并阅读源码,特别是​​@Conditional*​​注解,这可以帮你找出它们启用哪些特性及何时启用。 将​​--debug​​添加到命令行或添加系统属性​​-Ddebug​​可以在控制台查看日志,该日志会记录你的应用中所有自动配置的决策。在运行Actuator的app中,通过查看​​autoconfig​​端点(​​/autoconfig​​或等效的JMX)可以获取相同信息。
  • 查找​​@ConfigurationProperties​​的类(比如ServerProperties)并看下有哪些可用的外部配置选项。​​@ConfigurationProperties​​类有一个用于充当外部配置前缀的​​name​​属性,因此​​ServerProperties​​的​​prefix="server"​​,它的配置属性有​​server.port​​,​​server.address​​等。在运行Actuator的应用中可以查看​​configprops​​端点。
  • 查看​​RelaxedPropertyResolver​​明确地将配置从​​Environment​​暴露出去,它经常会使用前缀。
  • 查看​​@Value​​注解,它直接绑定到​​Environment​​。相比​​RelaxedPropertyResolver​​,这种方式稍微缺乏灵活性,但它也允许松散的绑定,特别是OS环境变量(所以​​CAPITALS_AND_UNDERSCORES​​是​​period.separated​​的同义词)。
  • 查看​​@ConditionalOnExpression​​注解,它根据SpEL表达式的结果来开启或关闭特性,通常使用解析自​​Environment​​的占位符进行计算。

启动前自定义Environment或ApplicationContext

每个​​SpringApplication​​​都有​​ApplicationListeners​​​和​​ApplicationContextInitializers​​​,用于自定义上下文(context)或环境(environment)。Spring Boot从​​META-INF/spring.factories​​下加载很多这样的内部使用的自定义,有很多方法可以注册其他的自定义:

  • 以编程方式为每个应用注册自定义,通过在​​SpringApplication​​运行前调用它的​​addListeners​​和​​addInitializers​​方法来实现。
  • 以声明方式为每个应用注册自定义,通过设置​​context.initializer.classes​​或​​context.listener.classes​​来实现。
  • 以声明方式为所有应用注册自定义,通过添加一个​​META-INF/spring.factories​​并打包成一个jar文件(该应用将它作为一个库)来实现。

​SpringApplication​​​会给监听器(即使是在上下文被创建之前就存在的)发送一些特定的​​ApplicationEvents​​​,然后也会注册监听​​ApplicationContext​​发布的事件的监听器,查看Spring Boot特性章节中的Section 23.5, “Application events and listeners” 可以获取完整列表。

在应用上下文刷新前使用​​EnvironmentPostProcessor​​​自定义​​Environment​​​是可能的,每个实现都需要注册到​​META-INF/spring.factories​​:

org.springframework.boot.env.EnvironmentPostProcessor=com.example.YourEnvironme

构建ApplicationContext层次结构(添加父级或根级上下文)

您可以使用​​ApplicationBuilder​​​该类来创建父/子​​ApplicationContext​​ 层次结构。

创建no-web应用

不是所有的Spring应用都必须是web应用(或web服务)。如果你想在​​main​​​方法中执行一些代码,但需要启动一个Spring应用去设置需要的底层设施,那使用Spring Boot的​​SpringApplication​​​特性可以很容易实现。​​SpringApplication​​​会根据它是否需要一个web应用来改变它的​​ApplicationContext​​​类,首先你需要做的是去掉servlet API依赖,如果不能这样做(比如基于相同的代码运行两个应用),那你可以明确地调用​​SpringApplication.setWebEnvironment(false)​​​或设置​​applicationContextClass​​​属性(通过Java API或使用外部配置)。你想运行的,作为业务逻辑的应用代码可以实现为一个​​CommandLineRunner​​​,并将上下文降级为一个​​@Bean​​定义。


举报

相关推荐

0 条评论