手记

Springboot单体架构搭建资料:新手入门教程

概述

本文提供了关于Spring Boot单体架构搭建资料的详细指南,包括开发环境的准备、项目创建及基本功能实现。文章不仅介绍了如何打包和部署Spring Boot应用程序,还详细涵盖了监控和日志管理的相关内容。通过本文的指导,读者可以快速搭建并运行一个功能完整的Spring Boot应用。

Spring Boot 简介

什么是 Spring Boot

Spring Boot 是一个基于 Spring 框架的开源框架,旨在简化新 Spring 应用程序的初始搭建以及开发过程。它通过约定优于配置的原则,尽可能减少开发者的工作量,使开发人员能够快速建立一个独立的、生产级别的应用。下面是一个简单的Spring Boot应用程序的启动类示例:

package com.example.demo;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class HelloApplication {
    public static void main(String[] args) {
        SpringApplication.run(HelloApplication.class, args);
    }
}

Spring Boot 的优势

  1. 快速启动:通过简化 Spring 应用程序的创建过程,Spring Boot 让开发者可以快速启动项目。例如,使用 @SpringBootApplication 注解可以自动配置应用程序。
  2. 自动配置:Spring Boot 通过一系列默认配置来设置应用程序,使配置变得相对简单。开发者可以自定义这些默认设置,以适应具体需求。例如,可以通过修改 application.properties 文件来调整应用程序的配置。
  3. 生产就绪:Spring Boot 提供多种应用于生产环境的特性,如性能监控、自动故障恢复等。例如,Spring Boot Actuator 提供了大量的生产就绪特性,可以通过 HTTP API 监控应用的运行状态。
  4. 依赖管理和打包:Spring Boot 自动处理依赖管理,以及打包应用程序,使其可以独立运行。例如,使用 Maven 或 Gradle 可以轻松地将应用程序打包成独立的 .jar 文件。
  5. 社区支持:Spring Boot 是由 Pivotal 公司开发的,拥有大量文档和活跃的社区支持。

Spring Boot 与传统 Spring 的区别

  • 配置简化:Spring Boot 通过约定优于配置的理念,减少了传统 Spring 项目的大量繁琐配置。例如,传统 Spring 项目可能需要手动配置数据源、事务管理器等,而 Spring Boot 可以通过自动配置大大简化这些工作。
  • 自动配置:Spring Boot 能自动配置 Bean,而传统 Spring 项目需要开发者手动配置大量 Bean。例如,传统 Spring 项目可能需要手动配置 DataSource Bean,而 Spring Boot 可以自动配置数据源。
  • 依赖管理和打包:Spring Boot 框架自动处理了项目的依赖管理和最终的打包,简化了开发流程。例如,使用 Maven 或 Gradle 可以轻松地将 Spring Boot 应用程序打包成一个独立的可执行 .jar 文件。
  • 社区和文档:Spring Boot 具有完善和丰富的文档,而传统 Spring 框架需要更多的手动配置和测试,文档不如 Spring Boot 详尽。
单体架构概述

单体架构的定义

单体架构(Monolithic Architecture)是一种常见的软件架构风格,其中整个应用程序作为一个单一的单元来开发、构建、部署和运行。在单体架构中,所有的功能模块都紧密地集成在一起,共享同一个代码库和部署环境。例如,一个简单的单体架构应用程序可能包含多个模块,如用户管理模块、订单管理模块等,它们之间紧密耦合。

单体架构的特点和优缺点

特点

  • 紧密集成:单体架构中所有的模块紧密耦合在一起,使得系统开发变得相对简单。例如,所有模块共享同一个数据库和代码库。
  • 部署简单:单体架构的应用程序可以作为一个整体部署,部署过程相对简单。例如,可以使用一个脚本来部署整个应用程序。
  • 维护简便:对于简单的应用,单体架构的维护相对简单。例如,可以一次性更新整个应用程序。

优点

  • 开发效率高:由于所有模块紧密集成在一起,开发效率较高,易于实现功能的快速开发和迭代。例如,可以快速添加新的功能模块。
  • 部署简单:整个应用可以作为一个单一的单元部署,不需要额外的协调工作。例如,可以使用一个脚本来部署整个应用程序。
  • 运维简单:运维团队只需要维护一个应用,相较于微服务架构,运维成本较低。例如,可以使用一个脚本监控整个应用程序。

缺点

  • 扩展性差:随着应用规模的扩大,单体架构变得越来越难以维护和扩展,模块之间的耦合度高,难以进行独立更新。例如,如果需要扩展订单模块,可能会影响整个应用程序。
  • 部署复杂:对于大型应用,每次部署都需要重新构建整个应用,耗费时间且复杂。例如,每次部署可能需要重启整个应用程序。
  • 性能瓶颈:单体架构中各个模块共享相同的内存和资源,容易形成性能瓶颈。例如,当一个模块的性能受到影响时,可能会影响整个应用程序。
  • 技术栈受限:由于所有模块共享一个代码库,采用同一套技术栈,限制了技术多样性的选择。例如,只能使用一种编程语言和数据库。

单体架构与微服务架构的区别

  • 模块划分:单体架构将所有功能模块集成在一个应用中,而微服务架构将应用划分为多个松散耦合的服务。例如,单体架构可能包含一个用户管理模块,而微服务架构可能将用户管理分为多个独立的服务。
  • 部署方式:单体架构部署简单,通常作为一个整体部署;微服务架构需要部署多个独立的服务。例如,单体架构可以使用一个脚本部署整个应用程序,而微服务架构需要为每个服务编写部署脚本。
  • 扩展性:单体架构扩展性较差,而微服务架构可以通过增加服务实例来提高扩展性。例如,可以为用户管理服务增加更多的实例来处理更多请求。
  • 技术栈:单体架构通常使用单一技术栈,而微服务架构可以使用多种不同的技术栈。例如,单体架构可能使用 Java 和 MySQL,而微服务架构可以使用 Java、Python 和 PostgreSQL。
准备开发环境

安装 JDK

Java 开发工具包(Java Development Kit,JDK)是开发 Java 应用程序的必备工具。以下是安装 JDK 的步骤:

  1. 访问 Oracle 官方网站或 OpenJDK 网站,下载适合您操作系统的 JDK 版本。
  2. 安装 JDK。在安装过程中,按照向导的提示完成安装步骤。
  3. 配置环境变量。需要将 JDK 的 bin 目录路径添加到系统的 PATH 环境变量中。例如,在 Windows 系统中,可以将路径添加到系统环境变量中;在 Linux 或 macOS 中,可以编辑配置文件 /etc/profile~/.bashrc,添加以下内容:

    export JAVA_HOME=/usr/lib/jvm/java-11-openjdk-amd64
    export PATH=$JAVA_HOME/bin:$PATH
  4. 验证安装。通过命令 java -version 检查 Java 版本是否正确显示。

安装 Maven 或 Gradle

Maven 和 Gradle 是两种流行的构建工具,用于自动化构建、测试和部署 Java 应用程序。以下是安装步骤:

Maven 安装

  1. 访问 Apache Maven 官方网站,下载适合您操作系统的 Maven 版本。
  2. 解压下载的 Maven 包,将其移动到您希望安装的位置,例如 C:\Program Files\ApacheMaven/usr/local/apache-maven
  3. 配置环境变量。将 Maven 的 bin 目录路径添加到系统的 PATH 环境变量中。例如,在 Windows 系统中,可以将路径添加到系统环境变量中;在 Linux 或 macOS 中,可以编辑配置文件 /etc/profile~/.bashrc,添加以下内容:

    export M2_HOME=/usr/local/apache-maven
    export PATH=$M2_HOME/bin:$PATH
  4. 验证安装。通过命令 mvn -version 检查 Maven 版本是否正确显示。

Gradle 安装

  1. 访问 Gradle 官方网站,下载适合您操作系统的 Gradle 版本。
  2. 解压下载的 Gradle 包,将其移动到您希望安装的位置,例如 C:\Program Files\gradle/usr/local/gradle
  3. 配置环境变量。将 Gradle 的 bin 目录路径添加到系统的 PATH 环境变量中。例如,在 Windows 系统中,可以将路径添加到系统环境变量中;在 Linux 或 macOS 中,可以编辑配置文件 /etc/profile~/.bashrc,添加以下内容:

    export GRADLE_HOME=/usr/local/gradle
    export PATH=$GRADLE_HOME/bin:$PATH
  4. 验证安装。通过命令 gradle -v 检查 Gradle 版本是否正确显示。

验证安装

为了确保安装成功,可以运行以下命令来验证安装:

java -version
mvn -version
gradle -v

安装 IDE(如 IntelliJ IDEA 或 Eclipse)

常用的 Java 开发 IDE 如 IntelliJ IDEA 和 Eclipse 为开发人员提供了丰富的开发工具,包括代码编辑、调试、版本控制功能等。以下是安装步骤:

IntelliJ IDEA 安装

  1. 访问 IntelliJ IDEA 官方网站,下载适合您操作系统和版本的 IntelliJ IDEA。
  2. 安装 IntelliJ IDEA。按照安装向导的提示完成安装步骤。
  3. 创建新项目。打开 IntelliJ IDEA,选择菜单 File -> New -> Project,选择 JavaSpring Initializr 模板,根据提示完成项目创建。

Eclipse 安装

  1. 访问 Eclipse 官方网站,下载适合您操作系统和版本的 Eclipse。
  2. 安装 Eclipse。按照安装向导的提示完成安装步骤。
  3. 创建新项目。打开 Eclipse,选择菜单 File -> New -> Project,选择 Java ProjectSpring Boot 项目模板,根据提示完成项目创建。
创建 Spring Boot 项目

使用 Spring Initializr 创建新项目

Spring Initializr 是一个在线工具,允许开发人员通过浏览器快速创建新的 Spring Boot 项目。以下是使用 Spring Initializr 创建新项目的步骤:

  1. 打开浏览器,访问 Spring Initializr 官方网站(https://start.spring.io/)。
  2. 在网站上选择项目信息,如项目语言(Java)、Spring Boot 版本、依赖库等。点击 Generate 生成项目。
  3. 下载生成的项目压缩包。例如,下载后可以解压到 C:\Projects\HelloWorld/home/yourname/Projects/HelloWorld
  4. 导入项目。将解压后的项目导入到您选择的 IDE 中,例如 IntelliJ IDEA 或 Eclipse。

添加依赖和配置文件

在创建的 Spring Boot 项目中,主要依赖于 pom.xml(Maven)或 build.gradle(Gradle)文件来管理项目依赖。以下是一个简单的 pom.xml 示例:

<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <!-- 其他依赖 -->
</dependencies>

一个简单的 build.gradle 示例:

dependencies {
    implementation 'org.springframework.boot:spring-boot-starter-web'
    // 其他依赖
}

运行第一个 Spring Boot 应用程序

  1. src/main/java 目录下创建主类。例如,创建一个 HelloApplication.java 文件:

    package com.example.demo;
    
    import org.springframework.boot.SpringApplication;
    import org.springframework.boot.autoconfigure.SpringBootApplication;
    import org.springframework.web.bind.annotation.GetMapping;
    import org.springframework.web.bind.annotation.RestController;
    
    @SpringBootApplication
    public class HelloApplication {
        public static void main(String[] args) {
            SpringApplication.run(HelloApplication.class, args);
        }
    }
  2. 在主类中添加一个简单的 REST API 控制器,例如 HelloController.java

    package com.example.demo;
    
    import org.springframework.web.bind.annotation.RestController;
    import org.springframework.web.bind.annotation.GetMapping;
    
    @RestController
    public class HelloController {
        @GetMapping("/hello")
        public String hello() {
            return "Hello World!";
        }
    }
  3. 运行应用程序。在 IDE 中,选择 HelloApplication 类,右键点击并选择 Run 或者使用命令 mvn spring-boot:rungradle bootRun 运行应用程序。
基本功能实现

创建基本的 REST API

在 Spring Boot 应用程序中,通过 @RestController 注解可以快速创建 REST API。例如,下面的代码展示了如何创建一个简单的 REST API:

package com.example.demo;

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

@RestController
public class HelloController {
    @GetMapping("/hello")
    public String hello() {
        return "Hello World!";
    }
}

使用 Spring MVC 处理请求

Spring MVC 是 Spring 框架的一部分,用于构建 Web 应用程序。在 Spring Boot 应用程序中,可以通过 @Controller@RequestMapping 注解来定义控制器和处理请求的方法。例如,下面的代码展示了如何定义一个简单的控制器:

package com.example.demo;

import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.PutMapping;
import org.springframework.web.bind.annotation.DeleteMapping;

@RestController
public class UserController {

    @GetMapping("/users")
    public String getUsers() {
        return "Get all users";
    }

    @PostMapping("/users")
    public String createUser() {
        return "Create new user";
    }

    @PutMapping("/users/{id}")
    public String updateUser() {
        return "Update user";
    }

    @DeleteMapping("/users/{id}")
    public String deleteUser() {
        return "Delete user";
    }
}

配置和使用数据库(如 MySQL 或 PostgreSQL)

在 Spring Boot 应用程序中,可以通过 application.propertiesapplication.yml 文件来配置数据库连接信息。例如,下面的代码展示了如何配置 MySQL 和 PostgreSQL 数据库:

MySQL 配置

application.properties 文件中:

spring.datasource.url=jdbc:mysql://localhost:3306/mydb
spring.datasource.username=root
spring.datasource.password=root
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.jpa.hibernate.ddl-auto=update

PostgreSQL 配置

application.properties 文件中:

spring.datasource.url=jdbc:postgresql://localhost:5432/mydb
spring.datasource.username=root
spring.datasource.password=root
spring.datasource.driver-class-name=org.postgresql.Driver
spring.jpa.hibernate.ddl-auto=update

定义实体类

例如,定义一个 User 实体类:

package com.example.demo.model;

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

@Entity
public class User {

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;
    private String name;
    private String email;

    // 构造函数、getter 和 setter 方法
}

定义仓库接口

为实体类创建对应的仓库接口,例如 UserRepository.java

package com.example.demo.repository;

import com.example.demo.model.User;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.stereotype.Repository;

@Repository
public interface UserRepository extends JpaRepository<User, Long> {
}

定义服务类

为仓库接口创建服务类,例如 UserService.java

package com.example.demo.service;

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

@Service
public class UserService {

    private final UserRepository userRepository;

    @Autowired
    public UserService(UserRepository userRepository) {
        this.userRepository = userRepository;
    }

    public User createUser(User user) {
        return userRepository.save(user);
    }

    public User getUserById(Long id) {
        return userRepository.findById(id).orElse(null);
    }

    public User updateUser(Long id, User user) {
        User existingUser = userRepository.findById(id).orElse(null);
        if (existingUser != null) {
            existingUser.setName(user.getName());
            existingUser.setEmail(user.getEmail());
            return userRepository.save(existingUser);
        }
        return null;
    }

    public void deleteUser(Long id) {
        userRepository.deleteById(id);
    }
}

使用服务类

在控制器中使用 UserService 来处理用户操作,例如 UserController.java

package com.example.demo.controller;

import com.example.demo.model.User;
import com.example.demo.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;

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

    @Autowired
    private UserService userService;

    // 创建用户
    @PostMapping
    public User createUser(@RequestBody User user) {
        return userService.createUser(user);
    }

    // 获取用户
    @GetMapping("/{id}")
    public User getUserById(@PathVariable Long id) {
        return userService.getUserById(id);
    }

    // 更新用户
    @PutMapping("/{id}")
    public User updateUser(@PathVariable Long id, @RequestBody User user) {
        return userService.updateUser(id, user);
    }

    // 删除用户
    @DeleteMapping("/{id}")
    public void deleteUser(@PathVariable Long id) {
        userService.deleteUser(id);
    }
}

通过以上步骤,可以完成基本的数据库操作,并为 REST API 提供相应的功能。

项目打包与部署

打包 Spring Boot 应用程序

在 Spring Boot 应用程序中,可以通过构建工具(Maven 或 Gradle)来打包应用程序。以下是打包步骤:

Maven 打包

在项目根目录下执行命令 mvn clean package,将会在 target 目录下生成一个 *.jar 文件。

Gradle 打包

在项目根目录下执行命令 gradle clean build,将会在 build/libs 目录下生成一个 *.jar 文件。

部署到本地或云服务器

将打包后的 *.jar 文件复制到服务器上,然后运行应用程序。

本地服务器部署

在本地服务器上运行 *.jar 文件:

java -jar target/helloworld.jar

云服务器部署

*.jar 文件上传到云服务器,并在服务器上运行:

java -jar /path/to/helloworld.jar

监控和日志管理

为了更好地监控和管理日志,可以使用一些工具来收集和分析日志信息。例如,可以在 application.properties 文件中配置日志输出:

spring.application.name=helloworld
logging.file.name=/var/log/helloworld.log
logging.level.root=INFO

可以使用一些监控工具如 Prometheus 和 Grafana 来监控应用程序的运行状态。以下是安装和配置监控工具的步骤:

安装 Prometheus 和 Grafana

  1. 在云服务器上安装 Prometheus 和 Grafana。
  2. 配置 Prometheus 监控应用程序。
  3. 使用 Grafana 分析和可视化监控数据。

通过以上步骤,可以完成 Spring Boot 应用程序的打包、部署、监控和日志管理。

0人推荐
随时随地看视频
慕课网APP