继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

Springboot单体架构搭建资料详解与实战教程

达令说
关注TA
已关注
手记 334
粉丝 22
获赞 120
概述

本文详细介绍了如何使用Spring Boot搭建单体架构应用,涵盖了环境搭建、常用功能实现、部署与优化等关键步骤。文章提供了丰富的代码示例和配置说明,帮助读者快速掌握Springboot单体架构搭建资料。

Spring Boot简介

什么是Spring Boot

Spring Boot 是一个基于 Spring 框架的 Java 应用程序开发工具。它通过简化配置、自动化配置和减少样板代码,使开发者能够快速构建独立的、生产级别的应用。Spring Boot 旨在简化 Spring 应用的初始配置和依赖管理,使得开发者可以专注于业务逻辑的开发。

Spring Boot的优势和特点

  1. 简易的项目配置

    • Spring Boot 通过约定优于配置的方式,自动配置了许多常用的场景,如数据库连接、Web 服务器等。
    • 开发者可以通过简单的注解和配置,快速搭建起应用的基础框架。
  2. 嵌入式Web服务器

    • Spring Boot 可以嵌入 Tomcat、Jetty 或 Undertow 等 Web 服务器,使得应用可以使用 mvn spring-boot:rungradle bootRun 命令直接运行,无需额外配置应用服务器。
  3. 自动配置

    • Spring Boot 自动配置了许多常用的场景,如数据源、连接池、事务管理等,减少了繁杂的手动配置。
  4. 起步依赖

    • Spring Boot 通过 starters 概念,提供了许多常用的依赖库,如 spring-boot-starter-webspring-boot-starter-data-jpa 等,简化了依赖管理。
  5. 外部化配置

    • Spring Boot 支持将配置文件从代码中分离出来,通过 application.propertiesapplication.yml 文件进行配置。此外,还可以通过环境变量、命令行参数等方式进行配置。
  6. 健康检查和监控

    • Spring Boot 提供了多种健康检查的端点,如 /actuator/health,可以通过这些端点检查应用的健康状况。
    • 同时,Spring Boot 还提供了 /actuator/info/actuator/metrics 等端点,方便开发者监控应用的运行状态。
  7. 快速构建可执行的JAR文件
    • Spring Boot 支持将应用打包成独立的可执行的 JAR 文件,方便部署和运行。

Spring Boot与传统Spring的区别

  1. 配置简化

    • 传统Spring:需要手动编写大量的 XML 配置文件或 @Configuration 类来配置应用。
    • Spring Boot:通过约定优于配置的方式,自动配置了许多常用的场景,如数据库连接、Web 服务器等。
  2. 依赖管理

    • 传统Spring:需要手动在 pom.xmlbuild.gradle 文件中添加所需的依赖。
    • Spring Boot:通过 spring-boot-starter 依赖集,简化了依赖管理,只需添加一个依赖即可引入一系列常用的库。
  3. 自动配置

    • 传统Spring:需要通过 @Configuration 注解手动配置 Bean。
    • Spring Boot:通过 @EnableAutoConfiguration 注解,自动配置了许多常用的场景。
  4. 运行环境

    • 传统Spring:通常需要部署到应用服务器(如 Tomcat)上运行。
    • Spring Boot:嵌入了 Web 服务器,可以通过 mvn spring-boot:rungradle bootRun 命令直接运行。
  5. 打包发布
    • 传统Spring:需要将应用打包成 WAR 文件,部署到应用服务器。
    • Spring Boot:可以将应用打包成独立的可执行的 JAR 文件,方便部署和运行。
单体架构基础

什么是单体架构

单体架构是一种将整个应用作为一个单一的可执行单元的架构方式。在这种架构中,所有的功能模块都部署在同一个进程中,共享同一个进程空间。单体架构通常将应用部署为一个 WAR 文件或 JAR 文件,易于构建、部署和测试。

单体架构的优点和缺点

优点

  1. 简单
    • 单体架构的代码结构简单,易于理解和维护。
  2. 快速部署
    • 由于整体架构比较简单,因此可以快速地进行构建和部署。
  3. 低学习成本
    • 开发者只需要关注一个应用,不需要学习复杂的分布式系统知识。
  4. 方便调试
    • 由于所有的代码都在一个进程中,调试起来相对简单。

缺点

  1. 扩展性差
    • 单体架构难以扩展单个模块,因为整个应用是一个整体。
  2. 代码复杂性增加
    • 随着应用规模的增长,单体架构的代码库会变得庞大和复杂,难以维护。
  3. 部署困难
    • 部署时需要重启整个应用,难以实现零停机时间。
  4. 开发速度受限
    • 单体架构中的模块互相依赖,导致开发速度受限,难以进行并行开发。

单体架构适用场景

  1. 小型应用
    • 对于规模较小的应用,使用单体架构可以简化开发和部署过程。
  2. 初期开发
    • 在应用开发初期,单体架构可以快速搭建起原型,便于快速验证和迭代。
  3. 业务简单
    • 对于业务单一、变化不大的应用,单体架构可以满足需求。

单体架构对比微服务架构

在单体架构和微服务架构的对比中,单体架构的优点主要体现在其简单性和快速部署,而缺点则在于其扩展性和维护性较差。相比之下,微服务架构通过将应用拆分成多个独立的服务,能够更好地支持应用的扩展和维护,但同时也带来了部署复杂性和开发难度增加的问题。

Spring Boot环境搭建

开发环境准备

开发工具

  1. IDE
    • 推荐使用 IntelliJ IDEA 或 Eclipse,它们对 Spring Boot 有很好的支持,提供了代码提示、自动补全等功能。
  2. 构建工具
    • 使用 Maven 或 Gradle 构建工具,这两种工具都支持 Spring Boot 项目。推荐使用 Maven,因为它是 Spring Boot 官方支持的构建工具。

安装 Java

确保已经安装了 Java 开发工具包(JDK)。推荐使用 Java 8 或更高版本。

创建Spring Boot项目

  1. 使用 Spring Initializr 创建项目

    • 访问 Spring Initializr 网站,选择项目配置。
    • 选择 Project 为 Maven 项目,Language 为 Java,Spring Boot 版本,选择所需依赖(如 Web、JPA 等)。
    • 生成项目压缩包,并解压到本地。
  2. 使用 IDE 创建项目
    • 在 IntelliJ IDEA 中,选择 File -> New -> Project -> Spring Initializr。
    • 在 Eclipse 中,选择 File -> New -> Spring Starter Project。

添加依赖和配置

Maven 项目配置

pom.xml 文件中添加所需的依赖:

<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-data-jpa</artifactId>
    </dependency>
    <dependency>
        <groupId>com.h2database</groupId>
        <artifactId>h2</artifactId>
        <scope>runtime</scope>
    </dependency>
</dependencies>

Gradle 项目配置

build.gradle 文件中添加所需的依赖:

dependencies {
    implementation 'org.springframework.boot:spring-boot-starter-web'
    implementation 'org.springframework.boot:spring-boot-starter-data-jpa'
    runtimeOnly 'com.h2database:h2'
}

配置数据库

application.properties 配置

spring.datasource.url=jdbc:h2:mem:testdb
spring.datasource.driverClassName=org.h2.Driver
spring.datasource.username=sa
spring.datasource.password=
spring.h2.console.enabled=true
spring.jpa.hibernate.ddl-auto=update

application.yml 配置

spring:
  datasource:
    url: jdbc:h2:mem:testdb
    driverClassName: org.h2.Driver
    username: sa
    password: 
  h2:
    console:
      enabled: true
jpa:
  hibernate:
    ddl-auto: update
Spring Boot常用功能实现

RESTful API开发

创建 RESTful API

创建一个简单的 RESTful API,用于查询用户信息。

package com.example.demo.controller;

import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import java.util.List;
import java.util.ArrayList;

@RestController
@RequestMapping("/users")
public class UserController {

    private List<User> users = new ArrayList<>();

    public UserController() {
        users.add(new User(1, "Alice", "alice@example.com"));
        users.add(new User(2, "Bob", "bob@example.com"));
    }

    @GetMapping("/")
    public List<User> getUsers() {
        return users;
    }
}

创建 User 类

package com.example.demo.model;

public class User {
    private int id;
    private String name;
    private String email;

    public User(int id, String name, String email) {
        this.id = id;
        this.name = name;
        this.email = email;
    }

    public int getId() {
        return id;
    }

    public String getName() {
        return name;
    }

    public String getEmail() {
        return email;
    }
}

测试 RESTful API

启动应用后,访问 http://localhost:8080/users/,会看到返回的用户列表。

数据库集成与操作

创建实体类

package com.example.demo.entity;

import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;

@Entity
public class UserEntity {
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;
    private String name;
    private String email;

    // Getters and Setters
}

创建 Repository 接口

package com.example.demo.repository;

import com.example.demo.entity.UserEntity;
import org.springframework.data.jpa.repository.JpaRepository;

public interface UserRepository extends JpaRepository<UserEntity, Long> {
}

创建 Service 类

package com.example.demo.service;

import com.example.demo.entity.UserEntity;
import com.example.demo.repository.UserRepository;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import java.util.List;

@Service
public class UserService {

    @Autowired
    private UserRepository userRepository;

    public List<UserEntity> getAllUsers() {
        return (List<UserEntity>) userRepository.findAll();
    }
}

修改控制器

package com.example.demo.controller;

import com.example.demo.service.UserService;
import com.example.demo.entity.UserEntity;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import java.util.List;

@RestController
@RequestMapping("/users")
public class UserController {

    private final UserService userService;

    public UserController(UserService userService) {
        this.userService = userService;
    }

    @GetMapping("/")
    public List<UserEntity> getUsers() {
        return userService.getAllUsers();
    }
}

日志管理与配置

配置日志框架

默认情况下,Spring Boot 使用 Logback 作为日志框架。

修改 application.properties 配置

logging.level.root=INFO
logging.level.com.example.demo=DEBUG

示例代码

package com.example.demo.config;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.boot.CommandLineRunner;
import org.springframework.stereotype.Component;

@Component
public class LoggingExample implements CommandLineRunner {

    private static final Logger logger = LoggerFactory.getLogger(LoggingExample.class);

    @Override
    public void run(String... args) throws Exception {
        logger.debug("Debug log");
        logger.info("Info log");
        logger.warn("Warn log");
        logger.error("Error log");
    }
}

异常处理

全局异常处理器

package com.example.demo.exception;

import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.ControllerAdvice;
import org.springframework.web.bind.annotation.ExceptionHandler;
import org.springframework.web.bind.annotation.ResponseBody;

@ControllerAdvice
public class GlobalExceptionHandler {

    @ExceptionHandler(Exception.class)
    @ResponseBody
    public ResponseEntity<String> handleException(Exception e) {
        return new ResponseEntity<>(e.getMessage(), HttpStatus.INTERNAL_SERVER_ERROR);
    }
}

示例控制器

package com.example.demo.controller;

import com.example.demo.exception.UserNotFoundException;
import com.example.demo.service.UserService;
import com.example.demo.entity.UserEntity;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import java.util.List;

@RestController
@RequestMapping("/users")
public class UserController {

    private final UserService userService;

    public UserController(UserService userService) {
        this.userService = userService;
    }

    @GetMapping("/")
    public List<UserEntity> getUsers() throws UserNotFoundException {
        List<UserEntity> users = userService.getAllUsers();
        if (users.isEmpty()) {
            throw new UserNotFoundException("No users found");
        }
        return users;
    }
}
单体架构下的Spring Boot应用部署

应用打包与发布

打包成 JAR 文件

mvn clean package

发布到远程服务器

将打包好的 JAR 文件上传到远程服务器,例如使用 SCP 命令:

scp target/project.jar user@remote-server:/path/to/deploy/

应用启动与调试

启动应用

java -jar project.jar

调试应用

在 IDE 中启动应用时,可以通过断点调试来调试代码。

应用监控与管理

使用 Actuator 端点

Spring Boot Actuator 提供了一系列端点来监控和管理应用。

启用 Actuator

pom.xmlbuild.gradle 中添加 spring-boot-starter-actuator 依赖:

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
implementation 'org.springframework.boot:spring-boot-starter-actuator'

访问 Actuator 端点

启动应用后,访问 http://localhost:8080/actuator,可以看到一系列端点,如 /health/info/metrics 等。

Spring Boot项目维护与优化

代码规范与最佳实践

代码规范

  • 命名规范
    • 类名采用驼峰命名法,首字母大写。
    • 变量名和方法名采用驼峰命名法,首字母小写。
    • 常量名全部大写,单词之间用下划线分隔。
  • 注释规范
    • 文件开头需要添加注释,说明文件的用途、作者、修改日期等。
    • 代码中需要添加足够的注释,解释复杂的逻辑。

最佳实践

  • 依赖管理

    • 使用 spring-boot-starter 来简化依赖管理。
    • pom.xmlbuild.gradle 文件中明确声明依赖版本。
  • 配置分离

    • 将配置文件从代码中分离出来,使用外部配置文件(如 application.propertiesapplication.yml)。
  • 单元测试

    • 使用单元测试框架(如 JUnit)编写单元测试,确保代码的正确性。
    • 使用 Mock 注解或库(如 Mockito)来模拟依赖。
  • 代码审查
    • 定期进行代码审查,确保代码质量。

示例代码

package com.example.demo.controller;

import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import java.util.List;
import java.util.ArrayList;

@RestController
@RequestMapping("/users")
public class UserController {

    private List<User> users = new ArrayList<>();

    public UserController() {
        users.add(new User(1, "Alice", "alice@example.com"));
        users.add(new User(2, "Bob", "bob@example.com"));
    }

    @GetMapping("/")
    public List<User> getUsers() {
        return users;
    }
}

性能优化与调优

优化数据库访问

  • 查询优化

    • 使用 @Query 注解来优化 SQL 查询。
    • 分析慢查询日志,优化查询语句。
  • 连接池配置
    • 调整连接池参数,如最大连接数、最大空闲连接数等。

优化内存使用

  • 内存调优
    • 调整 JVM 参数,如堆内存大小、垃圾回收器等。
    • 使用工具(如 VisualVM)监控内存使用情况。

优化缓存

  • 使用缓存
    • 使用 Spring Cache 注解或 Redis 等缓存中间件来缓存数据。
    • 合理设置缓存过期时间。

优化日志输出

  • 日志级别配置
    • 根据需要设置不同模块的日志级别,避免日志输出过多占用资源。

框架升级与兼容性处理

升级 Spring Boot 版本

  • 升级步骤

    • 修改 pom.xmlbuild.gradle 文件中的 Spring Boot 版本。
    • 修改依赖版本,确保与新版本兼容。
    • 重新编译和测试应用,确保没有兼容性问题。
  • 处理兼容性问题

    • 一些依赖库可能在新版本中变更了接口,导致不兼容。
    • 需要仔细阅读升级文档,修改代码以适应新版本的变更。
  • 依赖冲突
    • 使用 Maven 或 Gradle 的依赖树命令,检查是否有依赖冲突。
    • 调整依赖版本,解决冲突。

示例代码

<!-- 修改 Spring Boot 版本 -->
<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>2.5.4</version>
</parent>
// 修改 Spring Boot 版本
implementation 'org.springframework.boot:spring-boot-starter-web:2.5.4'
打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP