后端企业级开发之yaml数据序列化格式文件详解2024

本文涉及的产品
RDS DuckDB + QuickBI 企业套餐,8核32GB + QuickBI 专业版
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS AI 助手,专业版
简介: 后端企业级开发之yaml数据序列化格式文件详解2024

yaml格式

数据格式

yaml 是一种数据序列化的格式

容易阅读 容易与脚本语言交互 以数据为核心 重数据轻格式

我们要知道他怎么书写

大小写敏感

属性层级关系使用多行描述 每行结尾使用冒号结束

使用缩进表示层级关系

同层级左侧对其 只运行使用空格

属性前面添加空格

#表示注释

同样名称的属性只能出现一次

country: china
provice: beijing
city: beijing
area: beijing
 
port: 8080
 
party: true
 
birthday: 2003-12-04
 
user:
  name: zhudaoyang
  age: 21

# 多层级属性 以后使用频率比较高
a:
  b:
    c:
      d:
        e: 123
 
# 数组
likes1:
  - game
  - music
  - swim
 
# 数组
likes2: [game,music.sleep]
 
# 对象数组
users1:
  - name: gaochang
    age: 18
  - name: zhuaishao
    age: 18
 
# 对象数组
user2: [{name:gaochang,age:18},{name:zhuaishao,age:18}]

核心规则 数据前面要加空格隔开

读取单一属性性质

用Rest模式书写

@Value注解

@Value注解是Spring框架中的一个注解,用于将值注入到Spring Bean中。它通常用于将配置文件中的属性值注入到Spring Bean的字段或构造函数参数中。与@Autowired@Qualifier等注解相比,@Value注解更加简单直接,适用于简单的数值或字符串类型的注入。

在使用@Value注解时,你可以通过${}语法从属性文件中引用属性值,也可以直接指定一个常量值。

多种数据的读取

package com.bigdata1421.demo.controller;
 
import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
 
// Rest模式
@RestController
@RequestMapping("/yaml")
public class YamlController {
 
    //读取yaml数据中的单一数据
    //spring中为数据注入基本数据类型或者是字符串
    @Value("${country}")
    private String country;
 
    //一级一级的往下
    @Value("${user.name}")
    private String user_name;
 
    // 数组
    @Value("${likes1[1]}")
    private String like;
 
    //对象数组
    @Value("${user1[0].name}")
    private String gc_name;
 
    @GetMapping
    public String getById(){
        System.out.println("springboot is running");
        System.out.println("country ===>" + country);
        System.out.println("user1.name ===>" + user_name);
        System.out.println("like ===>" + like);
        System.out.println("gc_name ===>" + gc_name);
        return "springboot is running...";
    }
}

变量引用

使用${属性名}引用数据

baseDir: c:\windows
tempDir: c:\windows\temp
 
# 使用${属性名}引用数据
tempDir: ${baseDir}\temp

如果出现转义字符怎么修改

使用引号包裹的字符串其中的转义字符可以生效

读取全局属性

封装

一键搞定

用注解 @Autowired

@Autowired 是 Spring Framework 中的一个注解,用于自动装配依赖关系。在 Spring 应用程序中,通常会有很多不同的组件(如服务、存储库、控制器等),它们之间需要相互协作以完成业务逻辑。使用 @Autowired 注解,Spring 能够在运行时自动将依赖关系注入到组件中,而无需手动实例化这些依赖项。

当一个类标记了 @Autowired 注解时,Spring 容器会尝试在上下文中查找匹配该类型的 bean,并将其注入到目标类的相应字段、构造函数或者 setter 方法中。

在使用 @Autowired 注解时,有几种不同的方式可以指定注入的依赖:

  1. 字段注入:通过将 @Autowired 注解直接放在类的字段上来实现依赖注入。
  2. 构造函数注入:通过在类的构造函数上使用 @Autowired 注解来实现依赖注入。
  3. 方法注入:通过在类的方法上使用 @Autowired 注解来实现依赖注入。

package com.bigdata1421.demo.controller;
 
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.core.env.Environment;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
 
// Rest模式
@RestController
@RequestMapping("/yaml")
public class YamlController {
 
    //封装全部数据 自动装配注解
    //使用自动装配将所有数据封装到一个Environment对象里面去
    @Autowired
    private Environment env;
 
    @GetMapping
    public String getById(){
        System.out.println("springboot is running");
        System.out.println("tempDir===>" + env.getProperty("tempDir"));
        return "springboot is running...";
    }
}

封装全部数据到Environment对象

读取引用类型属性

以后boot开发

我们会有一个类似于对象的数据格式

然后把数据封装进去

封装数据应该针对封装

我们在拿的时候就可以拿取对应的一组数据即可

这是我们的痛点

springboot 主流的数据封装

# 创建类 用于封装下面的数据
# 由 spring 帮我们去加载数据到对象里面去 一定要告诉 spring 加载这组信息
# 使用的时候从 spring 中获取信息
 
datasource:
  driver: com.mysql.jbdc.Driver
  url: jdbc:mysql://localhost/springboot_db
  username: root
  password: root666

创建实体类封装数据

定义数据模型封装yml配置文件中的数据

我们加载的数据在配置文件中

配置文件是给spring用的

boot是为了加速spring开发的

所以我们要把对象交给spring管理控制

我们要定义为bean

注解@Component

指定加载的数据

注解 @ConfigurationPropertis

发起请求后 控制台输出信息

package com.bigdata1421.demo.datasource;
 
import lombok.EqualsAndHashCode;
import lombok.Getter;
import lombok.Setter;
import lombok.ToString;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.stereotype.Component;
 
@Component//定义为一个bean 交给spring去管理控制
@ConfigurationProperties(prefix = "datasource")//加载配置中的属性
 
@Setter
@Getter
@ToString
@EqualsAndHashCode
public class MyDataSource {
 
    // 数据封装
    private String driver;
    private String url;
    private String username;
    private String password;
 
}

application.yml 配置文件

配置文件中定义的是数据模型

# 创建类 用于封装下面的数据
# 由 spring 帮我们去加载数据到对象里面去 一定要告诉 spring 加载这组信息
# 使用的时候从 spring 中获取信息
 
datasource:
  driver: com.mysql.jbdc.Driver
  url: jdbc:mysql://localhost/springboot_db
  username: root
  password: root666

以后定义数据就是一堆一堆的

这一堆信息加载给哪个对象

那一组信息加载给哪个对象

而我们springboot管控的所有对象

要求的配置都从这里配置分发到各个对象里面去

再读取对应的数值

这里的所有对象都是通过这种形式 被tomcat服务器读取到的

这样可以增加目录级数

小结

模型类封装了yaml文件里的一部分

通过一个@ConfigurationProperties实现

指定封装的哪一组数据

这个模型类要定义为Spring的bean

通过注释@Component实现

再用@Autowired实现依赖注入bean

注意点

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
目录
相关文章
|
存储 缓存 负载均衡
后端开发中的性能优化策略
本文将探讨几种常见的后端性能优化策略,包括代码层面的优化、数据库查询优化、缓存机制的应用以及负载均衡的实现。通过这些方法,开发者可以显著提升系统的响应速度和处理能力,从而提供更好的用户体验。
578 6
|
JSON 自然语言处理 前端开发
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
707 72
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
|
10月前
|
人工智能 Java API
后端开发必看:零代码实现存量服务改造成MCP服务
本文介绍如何通过 **Nacos** 和 **Higress** 实现存量 Spring Boot 服务的零代码改造,使其支持 MCP 协议,供 AI Agent 调用。全程无需修改业务代码,仅通过配置完成服务注册、协议转换与工具映射,显著降低改造成本,提升服务的可集成性与智能化能力。
2903 1
|
10月前
|
前端开发 Java 数据库连接
后端开发中的错误处理实践:原则与实战
在后端开发中,错误处理是保障系统稳定性的关键。本文介绍了错误分类、响应设计、统一处理机制及日志追踪等实践方法,帮助开发者提升系统的可维护性与排障效率,做到防患于未然。
|
12月前
|
存储 消息中间件 前端开发
PHP后端与uni-app前端协同的校园圈子系统:校园社交场景的跨端开发实践
校园圈子系统校园论坛小程序采用uni-app前端框架,支持多端运行,结合PHP后端(如ThinkPHP/Laravel),实现用户认证、社交关系管理、动态发布与实时聊天功能。前端通过组件化开发和uni.request与后端交互,后端提供RESTful API处理业务逻辑并存储数据于MySQL。同时引入Redis缓存热点数据,RabbitMQ处理异步任务,优化系统性能。核心功能包括JWT身份验证、好友系统、WebSocket实时聊天及活动管理,确保高效稳定的用户体验。
632 4
PHP后端与uni-app前端协同的校园圈子系统:校园社交场景的跨端开发实践
|
前端开发 JavaScript 关系型数据库
2025 年前端与后端开发方向的抉择与展望-优雅草卓伊凡
2025 年前端与后端开发方向的抉择与展望-优雅草卓伊凡
903 5
2025 年前端与后端开发方向的抉择与展望-优雅草卓伊凡
|
人工智能 小程序 NoSQL
【一步步开发AI运动小程序】二十一、如何将AI运动项目配置持久化到后端?
本文介绍基于云智「Ai运动识别引擎」的运动配置持久化方案,旨在优化小程序或Uni APP中AI运动识别能力。通过将运动检测参数(如`Key`、`Name`、`TickMode`、`rules`或`samples`)持久化到后端,可避免因频繁调整运动参数而重新发布应用,提升用户体验。持久化数据结构支持规则和姿态样本存储,适用于关系数据库、文件或文档数据库(如MongoDB)。此外,云智还提供运动自动适配工具及「AI乐运动」产品,助力快速实现AI体育、全民健身等场景。
|
消息中间件 运维 安全
后端开发中的微服务架构实践与挑战####
在数字化转型的浪潮中,微服务架构凭借其高度的灵活性和可扩展性,成为众多企业重构后端系统的首选方案。本文将深入探讨微服务的核心概念、设计原则、关键技术选型及在实际项目实施过程中面临的挑战与解决方案,旨在为开发者提供一套实用的微服务架构落地指南。我们将从理论框架出发,逐步深入至技术细节,最终通过案例分析,揭示如何在复杂业务场景下有效应用微服务,提升系统的整体性能与稳定性。 ####
337 32
|
运维 监控 Java
后端开发中的微服务架构实践与挑战####
在数字化转型加速的今天,微服务架构凭借其高度的灵活性、可扩展性和可维护性,成为众多企业后端系统构建的首选方案。本文深入探讨了微服务架构的核心概念、实施步骤、关键技术考量以及面临的主要挑战,旨在为开发者提供一份实用的实践指南。通过案例分析,揭示微服务在实际项目中的应用效果,并针对常见问题提出解决策略,帮助读者更好地理解和应对微服务架构带来的复杂性与机遇。 ####
|
前端开发 Java 数据库连接
Java后端开发-使用springboot进行Mybatis连接数据库步骤
本文介绍了使用Java和IDEA进行数据库操作的详细步骤,涵盖从数据库准备到测试类编写及运行的全过程。主要内容包括: 1. **数据库准备**:创建数据库和表。 2. **查询数据库**:验证数据库是否可用。 3. **IDEA代码配置**:构建实体类并配置数据库连接。 4. **测试类编写**:编写并运行测试类以确保一切正常。
767 2