Spring Cloud Alibaba 实战(二) - 关于Spring Boot你不可不知道的实情

简介: 0 相关源码1 什么是Spring Boot一个快速开发的脚手架作用快速创建独立的、生产级的基于Spring的应用程序特性无需部署WAR文件提供starter简化配置尽可能自动配置Spring以及第三方库提供“生产就绪”功能,例如指标、健康检查、外部配置等无代码生成&无XML2 编写一个Spring Boot应用2.

0 相关源码

1 什么是Spring Boot

一个快速开发的脚手架

作用

快速创建独立的、生产级的基于Spring的应用程序

特性

  • 无需部署WAR文件
  • 提供starter简化配置
  • 尽可能自动配置Spring以及第三方库
  • 提供“生产就绪”功能,例如指标、健康检查、外部配置等
  • 无代码生成&无XML

2 编写一个Spring Boot应用

2.1 需求

  • 整合Spring MVC
  • /test路径(端点)

2.2 使用Spring Initializr快速创建Spring Boot应用

  • 编写测试代码
  • 运行输出

也可以使用

  • mvn clean install确保打包成功
  • java -jar 运行程序

3 组成分析

  • pom.xml
  • 配置文件
  • static目录
    存放静态文件
  • template目录
    存放模板文件,已过时

4 开发利器

添加依赖

写注解

写配置

5 Spring Boot Actuator

什么是Spring Boot Actuator

整合

健康信息

健康信息可以检查应用的运行状态,它经常被监控软件用来提醒人们生产环境是否存在问题。health端点暴露的默认信息取决于端点是如何被访问的。对于一个非安全,未认证的连接只返回一个简单的'status'信息。对于一个安全或认证过的连接其他详细信息也会展示
Spring Boot包含很多自动配置的HealthIndicators,你也可以写自己的。

自动配置的HealthIndicators

Spring Boot在合适的时候会自动配置以下HealthIndicators:

  • 下表显示了内置状态的默认状态映射:
  • 让我们配置一下health节点,并重启应用
  • 可看到对于磁盘的监控信息

应用信息

应用信息会暴露所有InfoContributor beans收集的各种信息,Spring Boot包含很多自动配置的InfoContributors,你也可以编写自己的实现。

自动配置的InfoContributors

Spring Boot会在合适的时候自动配置以下InfoContributors:

注 使用management.info.defaults.enabled属性可禁用以上所有InfoContributors。

自定义应用info信息

通过设置Spring属性info.*,你可以定义info端点暴露的数据。所有在info关键字下的Environment属性都将被自动暴露,例如,你可以将以下配置添加到application.properties:

info.app.encoding=UTF-8
info.app.java.source=1.8
info.app.java.target=1.8

注 你可以在构建时扩展info属性,而不是硬编码这些值。假设使用Maven,你可以按以下配置重写示例:

info.app.encoding=@project.build.sourceEncoding@
info.app.java.source=@java.version@
info.app.java.target=@java.version@

Git提交信息

info端点的另一个有用特性是,在项目构建完成后发布git源码仓库的状态信息。如果GitProperties bean可用,Spring Boot将暴露git.branch,git.commit.id和git.commit.time属性。

注 如果classpath根目录存在git.properties文件,Spring Boot将自动配置GitProperties bean。查看Generate git information获取更多详细信息。

使用management.info.git.mode属性可展示全部git信息(比如git.properties全部内容):

management.info.git.mode=full

构建信息

如果BuildProperties bean存在,info端点也会发布你的构建信息。

注 如果classpath下存在META-INF/build-info.properties文件,Spring Boot将自动构建BuildProperties bean。Maven和Gradle都能产生该文件

  • 配置info
  • 启动观察输出信息
  • SpringBoot支持很多端点,除了默认显示的几个,还可以激活暴露所有端点

  • 如果只想暴露某个端点也是可以的
  • 查看JVM最大内存

6 Spring Boot配置管理

yml配置

  • 注意缩进同一与冒号左右的空格
  • 注意与properties文件的不同

配置管理的各种姿势

配置管理常用方式

  • 配置文件
  • 环境变量
  • 外部配置文件
    会读取和jar文件相同路径下的配置文件,且优先级高于jar配置
  • 命令行参数

尽量保持配置最简单且统一,规避优先级冲突问题!

7 Profile

不同环境不同配置

使用

  • yml配置文件

  • 添加参数并启动程序
  • 查看端点以确认信息
  • 那么如果不指定参数呢,又运行的何种环境呢,让我们来看一下:
  • 默认是default,难道我非要将dev环境改为default才可以使用默认配置?显然SpringBoot另辟蹊径:

如果不是yml文件,而是用properties配置呢


  • 指定参数

  • 默认dev
  • 注意先将启动参数prod关闭,避免配置优先级冲突!

8 总结

  • 使用Spring Initializr快速创建应用
  • 应用组成分析
  • 开发三部曲
  • Actuator
  • 配置管理
  • Profile

参考

Spring Boot官方文档

目录
相关文章
|
3月前
|
人工智能 Java Nacos
基于 Spring AI Alibaba + Nacos 的分布式 Multi-Agent 构建指南
本文将针对 Spring AI Alibaba + Nacos 的分布式多智能体构建方案展开介绍,同时结合 Demo 说明快速开发方法与实际效果。
2892 69
|
3月前
|
人工智能 运维 Java
Spring AI Alibaba Admin 开源!以数据为中心的 Agent 开发平台
Spring AI Alibaba Admin 正式发布!一站式实现 Prompt 管理、动态热更新、评测集构建、自动化评估与全链路可观测,助力企业高效构建可信赖的 AI Agent 应用。开源共建,现已上线!
4707 74
|
3月前
|
监控 Cloud Native Java
Spring Boot 3.x 微服务架构实战指南
🌟蒋星熠Jaxonic,技术宇宙中的星际旅人。深耕Spring Boot 3.x与微服务架构,探索云原生、性能优化与高可用系统设计。以代码为笔,在二进制星河中谱写极客诗篇。关注我,共赴技术星辰大海!(238字)
Spring Boot 3.x 微服务架构实战指南
|
3月前
|
XML Java 测试技术
《深入理解Spring》:IoC容器核心原理与实战
Spring IoC通过控制反转与依赖注入实现对象间的解耦,由容器统一管理Bean的生命周期与依赖关系。支持XML、注解和Java配置三种方式,结合作用域、条件化配置与循环依赖处理等机制,提升应用的可维护性与可测试性,是现代Java开发的核心基石。
|
3月前
|
人工智能 监控 Java
Spring AI Alibaba实践|后台定时Agent
基于Spring AI Alibaba框架,可构建自主运行的AI Agent,突破传统Chat模式限制,支持定时任务、事件响应与人工协同,实现数据采集、分析到决策的自动化闭环,提升企业智能化效率。
Spring AI Alibaba实践|后台定时Agent
|
SpringCloudAlibaba API 开发者
新版-SpringCloud+SpringCloud Alibaba
新版-SpringCloud+SpringCloud Alibaba
|
10月前
|
负载均衡 Dubbo Java
Spring Cloud Alibaba与Spring Cloud区别和联系?
Spring Cloud Alibaba与Spring Cloud区别和联系?
|
11月前
|
人工智能 SpringCloudAlibaba 自然语言处理
SpringCloud Alibaba AI整合DeepSeek落地AI项目实战
在现代软件开发领域,微服务架构因其灵活性、可扩展性和模块化特性而受到广泛欢迎。微服务架构通过将大型应用程序拆分为多个小型、独立的服务,每个服务运行在其独立的进程中,服务与服务间通过轻量级通信机制(通常是HTTP API)进行通信。这种架构模式有助于提升系统的可维护性、可扩展性和开发效率。
3972 2
|
SpringCloudAlibaba 负载均衡 Dubbo
【SpringCloud Alibaba系列】Dubbo高级特性篇
本章我们介绍Dubbo的常用高级特性,包括序列化、地址缓存、超时与重试机制、多版本、负载均衡。集群容错、服务降级等。
1859 6
【SpringCloud Alibaba系列】Dubbo高级特性篇