Spring Boot最核心的三大注解
由于功能的迭代,Spring 变得越来越复杂。访问https://spring.io/projects
,可以看到所有在应用程序中使用的不同功能的 Spring 项目。启动一个新的 Spring 项目,必须添加构建路径或 maven 依赖项,配置 application server,添加 spring 配置等等,需要大量的工作,因为必须从头开始做所有事情。Spring Boot 应运而生。Spring Boot 构建在现有 Spring 框架之上。Spring Boot 避免了以前必须执行的所有样板代码和配置,帮助开发者更健壮地使用现有的 Spring 功能,并且只需最少的工作量。
Spring Boot 应用程序可以使用 Maven 和 Gradle 开发。
Spring JavaConfig 是 Spring 社区的一个产品,它提供了一种纯 java 方法来配置 Spring IoC 容器。因此,它有助于避免使用 XML 配置。使用 JavaConfig 的优点是:
可以通过开发工具来实现。有了这个依赖项,保存的任何更改都将重新启动嵌入的 tomcat。Spring Boot 有一个开发人员工具(DevTools)模块,它有助于提高开发人员的工作效率。Java 开发者面临的关键挑战之一是将文件更改自动部署到服务器并自动重启服务器。开发者可以在 Spring 引导时重新加载更改,而不必重新启动服务器。这将消除每次手动部署更改的需要。Spring Boot 在发布第一个版本时没有这个特性。这是开发者最需要的特性。DevTools 模块完全满足开发人员的需求。此模块将在生产环境中禁用。它还提供了 H2-database 控制台,以便更好地测试应用程序。使用以下依赖项
<dependency>
<groupId>org.springframework.bootgroupId>
<artifactId>spring-boot-devtoolsartifactId>
<optional>trueoptional>
dependency>
Spring Boot WAR部署
将基于Spring的WAR应用程序部署到Docker
将基于Spring的JAR应用程序部署到Docker
Spring boot actuator是Spring boot framework的重要特性之一。Spring boot actuator帮助您访问生产环境中正在运行的应用程序的当前状态,在生产环境中必须检查和监视几个指标。甚至一些外部应用程序也可能使用这些服务来触发对相关人员的警报消息。actuator模块公开一组REST端点,这些端点可以作为HTTP URL直接访问,以检查状态。
默认情况下,所有敏感的HTTP端点都是安全的,只有具有ACTUATOR角色的用户才能访问它们。安全性是使用标准HttpServletRequest.isUserInRole方法实现的。
我们可以使用-禁用安全性management.security.enabled = false
建议仅当在防火墙后访问ACTUATOR端点时禁用安全性。
要在自定义端口上运行spring引导应用程序,可以在application.properties中指定端口:server.port = 8090
ELK堆栈由三个开源产品组成——Elasticsearch、Logstash和Kibana from Elastic。
Elasticsearch是一个基于Lucene搜索引擎的NoSQL数据库。
Logstash是一个日志管道工具,它接受来自不同来源的输入,执行不同的转换,并将数据导出到不同的目标。它是一个动态的数据收集管道,具有可扩展的插件生态系统和强大的弹性搜索协同作用
Kibana是一个可视化UI层,工作在Elasticsearch之上。
这三个项目一起用于各种环境中的日志分析。因此Logstash收集和解析日志、弹性搜索索引并存储这些信息,而Kibana提供了一个UI层,提供可操作的可见性。
SpringBoot为编写单元测试用例提供了@SpringBootTest
YAML是一种人类可读的数据序列化语言。它通常用于配置文件。与属性文件相比,YAML文件的结构更加结构化,如果我们希望在配置文件中添加复杂的属性,那么它不会造成太大的混乱。可以看到,YAML具有分层的配置数据。
为了实现Spring Boot的安全性,使用Spring - Boot -starter-security依赖项,必须添加安全配置。它只需要很少的代码。Config类必须扩展WebSecurityConfigurerAdapter并覆盖它的方法。
为了集成Spring Boot和ActiveMQ,我们使用Spring - Boot -starter- ActiveMQ依赖项,它只需要很少的配置,没有样板代码。
为了集成Spring Boot和Apache Kafka,我们使用Spring - Kafka依赖项。
使用Spring Boot实现分页非常简单。使用Spring Data-JPA,这是通过传递可分页的org.springframe .data.domain来实现的。可分页到存储库方法。
Swagger被广泛用于可视化api,Swagger UI为前端开发人员提供在线沙箱环境。Swagger是一种工具、规范和完整的框架实现,用于生成RESTful Web服务的可视化表示。它允许文档以与服务器相同的速度更新。当通过Swagger正确定义时,使用者可以用最少的实现逻辑理解远程服务并与之交互。因此Swagger消除了调用服务时的猜测。
Spring Profiles允许用户根据配置文件(dev, test, prod等)注册bean。因此,当应用程序在开发中运行时,只能加载某些bean,当应用程序在生产中运行时,只能加载某些其他bean。假设我们的需求是Swagger文档只对QA环境启用,对所有其他环境禁用。这可以使用配置文件来完成。Spring Boot使得使用配置文件非常容易。
Spring Boot Batch提供了处理大量记录所必需的可重用功能,包括日志/跟踪、事务管理、作业处理统计信息、作业重启、作业跳过和资源管理。它还提供了更高级的技术服务和特性,通过优化和分区技术,这些特性将支持极高容量和高性能的批处理作业。无论是简单的还是复杂的,大容量批处理作业都可以以高度可伸缩的方式利用该框架来处理大量信息。
FreeMarker是一个基于java的模板引擎,最初专注于使用MVC软件架构生成动态web页面。使用Freemarker的主要优势是完全分离了表示层和业务层。程序员可以处理应用程序代码,而设计人员可以处理html页面设计。最后,使用freemarker,这些可以组合在一起,给出最终的输出页面。
Spring提供了一种非常有用的方法,可以使用ControllerAdvice处理异常。我们将实现一个ControlerAdvice类,它将处理控制器类抛出的所有异常。
缓存是本地内存的一个区域,它保存了频繁访问的数据的副本,否则获取或计算这些数据将非常消耗资源。使用Hazelcast进行缓存。
是的。使用Spring Boot公开了要使用的web服务。使用契约优先的方法从wsdl生成类。
Spring引导教程-Spring Data JPA
使用Spring MVC HandlerInterceptor与Spring引导
使用过不同的starter依赖项,如spring-boot-starter-activemq依赖项、spring-boot-starter-security依赖项、spring-boot-starter-web依赖项。这有助于减少依赖项的数量,并减少版本组合。
CSRF代表跨站请求伪造。它是一种攻击,迫使最终用户在其当前已经过身份验证的web应用程序上执行不需要的操作。CSRF攻击专门针对状态更改请求,而不是数据窃取,因为攻击者无法看到对伪造请求的响应。
gzip是一种文件格式,是一种用于文件压缩和解压缩的软件应用程序。
已将Apache Camel与Spring引导集成。使用Apache Camel Spring启动启动依赖项。
JSP是为网页量身定做的,Freemarker模板是一种更通用的模板语言——它可以用来生成html、纯文本、电子邮件等。
WebSocket是一种计算机通信协议,通过单个TCP连接提供全双工通信通道。
WebSocket是双向的——使用WebSocket客户端或服务器都可以发起发送消息。
WebSocket是全双工的——客户端和服务器之间的通信是相互独立的。
单个TCP连接——初始连接使用HTTP,然后将此连接升级为基于套接字的连接。然后,这个单一连接将用于未来的所有通信
轻- WebSocket消息数据交换比http轻得多。
在软件开发过程中,跨越应用程序多个点的功能称为横切关注点。这些横切关注点不同于应用程序的主要业务逻辑。因此,将这些横切关注点从业务逻辑中分离出来是面向方面编程(AOP)的切入点。
apache Kafka是一个分布式发布-订阅消息传递系统。它是一个可伸缩的、容错的、发布-订阅消息传递系统,使我们能够构建分布式应用程序。Kafka适用于离线和在线的消息消费。
Spring Boot提供了actuator 端点来监控单个微服务的指标。这些端点对于获取关于应用程序的信息非常有帮助,比如应用程序是否启动,它们的组件(如数据库等)是否正常工作。但是,使用actuator 接口的一个主要缺点或困难是,我们必须逐个命中这些接口,以了解应用程序的状态或健康状况。假设微服务涉及50个应用程序,管理员将不得不命中所有50个应用程序的actuator 端点。
使用过Netflix Eureka等Spring Cloud组件进行服务注册,Ribbon用于负载平衡。
Deploying Spring Boot Application to PCF
这个注解是 Spring Boot 项目的基石,创建 Spring Boot 项目之后会默认在主类加上。虽然开发者一般不会主动去使用它。
@SpringBootApplication
public class SpringSecurityJwtGuideApplication {
public static void main(java.lang.String[] args) {
SpringApplication.run(MchopinApplication.class, args);
}
}
@SpringBootApplication
可以看作是@Configuration
、@ComponentScan
、@EnableAutoConfiguration
注解的集合。
package org.springframework.boot.autoconfigure;
@Target(ElementType.TYPE)
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Inherited
@SpringBootConfiguration
@EnableAutoConfiguration
@ComponentScan(excludeFilters = {
@Filter(type = FilterType.CUSTOM, classes = TypeExcludeFilter.class),
@Filter(type = FilterType.CUSTOM, classes = AutoConfigurationExcludeFilter.class) })
public @interface SpringBootApplication {
......
}
package org.springframework.boot;
@Target(ElementType.TYPE)
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Configuration
public @interface SpringBootConfiguration {
}
根据 SpringBoot 官网,这三个注解的作用分别是:
1️⃣@Configuration:允许在 Spring 上下文中注册额外的 bean 或导入其他配置类
2️⃣@ComponentScan: 扫描被@Component (@Service,@Controller)注解的 bean,注解默认会扫描该类所在的包下所有的类。
3️⃣@EnableAutoConfiguration:启用 SpringBoot 的自动配置机制
#附、简化配置
它使用 “习惯优于配置” (项目中存在大量的配置,此外还内置一个习惯性的配置)的理念让项目快速运行起来。它并不是什么新的框架,而是默认配置了很多框架的使用方式,就像 Maven 整合了所有的 jar 包一样,Spring Boot 整合了所有框架。
1️⃣普通配置:server.port=8080
2️⃣自定义属性配置:类中@Value("${property}")
读取
3️⃣配置变量的引用
xxp.name=ncc
xxp.hello=HelloWorld! ${xxp.name}
4️⃣随机值配置
xxp.number=${random.int}
server.port=${random.int[1024,9999]}
5️⃣yml配置文件:一种配置文件语言。树状结构。