如何使用 SpringBoot 和 Docker 技术,实现一次构建到处运行的应用程序?

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
云数据库 RDS PostgreSQL,高可用系列 2核4GB
简介: 如何使用 SpringBoot 和 Docker 技术,实现一次构建到处运行的应用程序?

随着云计算、容器化等技术的发展和普及,业界对于部署和维护应用程序的要求也愈发严格。使用传统的部署方式,需要为不同的操作系统、硬件环境和配置参数分别编译和打包,增加了开发和运维人员的工作量和难度。而使用 Docker 技术,可以将应用程序与所需的依赖项封装为一个镜像,使其能够在任何地方以相同的方式运行,实现了一次构建到处运行的目标。本文介绍如何使用 SpringBoot 和 Docker 技术,实现一次构建到处运行的应用程序。

环境准备

在使用 SpringBoot 和 Docker 技术之前,需要安装和配置相应的开发环境和工具。本文使用的开发环境为:

  • Java 8
  • Maven
  • IntelliJ IDEA
  • Docker

请确保已经正确安装了以上环境和工具,并且能够正常使用。

创建 SpringBoot 项目

首先,我们创建一个 SpringBoot 项目作为演示。使用 IntelliJ IDEA 新建项目,选择 Spring Initializr,填写项目基本信息后,点击下一步进入依赖选择页面。这里我们选择 Web、JPA、MySQL 等常用依赖,点击完成,即可创建一个基本的 SpringBoot 项目。

编写应用程序

接下来,编写一个简单的应用程序,实现用户名的增删改查功能。为了演示方便,我们使用内存数据库 H2,省去了安装和配置 MySQL 数据库的步骤。

首先,定义一个 User 实体类,表示用户信息:

@Entity
@Table(name = "t_user")
@Data
public class User {
   
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;

    @NotBlank
    private String name;

    public User(String name) {
   
        this.name = name;
    }

    // 省略 getter 和 setter 方法
}

然后,定义一个 UserRepository 接口,继承 JpaRepository,提供增删改查等基本方法:

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

最后,实现一个 UserController,处理用户请求:

@RestController
@RequestMapping("/user")
public class UserController {
   
    @Autowired
    private UserRepository userRepository;

    @PostMapping
    public User create(@RequestBody User user) {
   
        return userRepository.save(user);
    }

    @GetMapping("/{id}")
    public User getById(@PathVariable Long id) {
   
        return userRepository.findById(id).orElse(null);
    }

    @PutMapping("/{id}")
    public User updateById(@PathVariable Long id, @RequestBody User user) {
   
        user.setId(id);
        return userRepository.save(user);
    }

    @DeleteMapping("/{id}")
    public void deleteById(@PathVariable Long id) {
   
        userRepository.deleteById(id);
    }
}

到此,基本的应用程序编写完成。

构建 Docker 镜像

接下来,我们使用 Docker 将应用程序打包成镜像,并在运行时加入所需的依赖项。

首先,创建一个 Dockerfile 文件,指定基础镜像、将应用程序打包成 Jar 包并复制到镜像中、设置容器启动命令等:

FROM openjdk:8-jdk-alpine
VOLUME /tmp
ARG JAR_FILE=target/*.jar
COPY ${JAR_FILE} app.jar
ENTRYPOINT ["java","-jar","/app.jar"]

然后,在项目根目录下执行以下命令,构建 Docker 镜像:

docker build -t myapp:latest .

其中,myapp 为镜像名称,latest 为标签。如果需要指定版本号,可以使用 myapp:1.0 等格式。

构建完成后,可以使用以下命令查看所有已经构建的镜像:

docker images

运行 Docker 容器

完成镜像构建后,可以使用以下命令启动一个容器实例:

docker run -p 8080:8080 myapp:latest

其中,-p 8080:8080 表示将容器的 8080 端口映射到主机的 8080 端口,myapp:latest 表示使用刚刚构建的镜像。

启动后,可以在浏览器中访问 http://localhost:8080/user 查看应用程序运行情况。

使用 Docker Compose 管理多个容器

在对 SpringBoot 应用程序进行部署时,除了应用本身的镜像,在生产环境中常常需要一些辅助的服务,例如数据库、Redis 缓存、消息队列等。这些服务可以单独使用 Docker 镜像进行部署,也可以使用 Docker Compose 进行管理。

Docker Compose 是一个简化部署过程的工具,可以管理多个 Docker 容器。使用 Docker Compose,可以通过配置文件一次性启动完整的应用程序,并自动创建和管理所有必需的容器。

下面,我们通过一个示例,演示如何使用 Docker Compose 管理多个容器。

首先,定义一个 docker-compose.yml 文件,指定需要启动的服务和参数。在本例中,我们使用 MySQL 作为数据库服务:

version: '3.5'
services:
  app:
    build: .
    ports:
      - "8080:8080"
    depends_on:
      - db
  db:
    image: mysql:8
    environment:
      MYSQL_ROOT_PASSWORD: rootpassword
      MYSQL_USER: mydbuser
      MYSQL_PASSWORD: mydbpass
      MYSQL_DATABASE: mydb
    ports:
      - "3306:3306"
    volumes:
      - ./mysql_data:/var/lib/mysql

其中,app 表示将启动应用程序的容器;build: . 表示使用当前目录下的 Dockerfile 构建镜像;ports: - "8080:8080" 表示将容器的 8080 端口映射到主机的 8080 端口;depends_on 表示在启动应用程序之前,需要先启动 db 容器;db 表示将启动 MySQL 数据库容器;image: mysql:8 表示使用 MySQL 官方提供的镜像;environment 表示设置环境变量,指定数据库的用户名、密码、数据库名称等;ports 表示将容器的 3306 端口映射到主机的 3306 端口;volumes 表示将容器内的 /var/lib/mysql 目录挂载到主机的 ./mysql_data/ 目录,实现数据持久化。

保存文件后,使用以下命令启动所有服务:

docker-compose up

启动完成后,可以使用以下命令查看所有已经启动的容器:

docker ps

此时,可以通过访问 http://localhost:8080/user 测试应用程序是否能够正常运行,并且能够使用 MySQL 数据库进行数据存储。如果需要停止所有容器,可以使用以下命令:

docker-compose down

总结

本文介绍了如何使用 SpringBoot 和 Docker 技术,实现一次构建到处运行的应用程序。首先,创建一个基本的 SpringBoot 项目,然后编写应用程序,实现用户名的增删改查功能。然后,使用 Docker 将应用程序打包成镜像,并在运行时加入所需的依赖项。最后,演示了如何使用 Docker Compose 管理多个容器,快速部署完整的应用程序。

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
目录
相关文章
|
3月前
|
Java 数据库连接 API
Java 8 + 特性及 Spring Boot 与 Hibernate 等最新技术的实操内容详解
本内容涵盖Java 8+核心语法、Spring Boot与Hibernate实操,按考试考点分类整理,含技术详解与代码示例,助力掌握最新Java技术与应用。
112 2
|
2月前
|
Kubernetes Cloud Native 持续交付
Docker:轻量级容器化技术解析
Docker:轻量级容器化技术解析
|
2月前
|
运维 测试技术 Docker
Docker:轻量级容器化技术革命
Docker:轻量级容器化技术革命
|
6月前
|
前端开发 Java 物联网
智慧班牌源码,采用Java + Spring Boot后端框架,搭配Vue2前端技术,支持SaaS云部署
智慧班牌系统是一款基于信息化与物联网技术的校园管理工具,集成电子屏显示、人脸识别及数据交互功能,实现班级信息展示、智能考勤与家校互通。系统采用Java + Spring Boot后端框架,搭配Vue2前端技术,支持SaaS云部署与私有化定制。核心功能涵盖信息发布、考勤管理、教务处理及数据分析,助力校园文化建设与教学优化。其综合性和可扩展性有效打破数据孤岛,提升交互体验并降低管理成本,适用于日常教学、考试管理和应急场景,为智慧校园建设提供全面解决方案。
400 70
|
4月前
|
SQL Java 数据库
解决Java Spring Boot应用中MyBatis-Plus查询问题的策略。
保持技能更新是侦探的重要素质。定期回顾最佳实践和新技术。比如,定期查看MyBatis-Plus的更新和社区的最佳做法,这样才能不断提升查询效率和性能。
170 1
|
5月前
|
安全 Java API
Spring Boot 功能模块全解析:构建现代Java应用的技术图谱
Spring Boot不是一个单一的工具,而是一个由众多功能模块组成的生态系统。这些模块可以根据应用需求灵活组合,构建从简单的REST API到复杂的微服务系统,再到现代的AI驱动应用。
|
7月前
|
存储 虚拟化 Docker
|
7月前
|
安全 API 算法框架/工具
大模型文件Docker镜像化部署技术详解
大模型文件Docker镜像化部署技术详解
917 2
|
20天前
|
前端开发 安全 Java
基于springboot+vue开发的会议预约管理系统
一个完整的会议预约管理系统,包含前端用户界面、管理后台和后端API服务。 ### 后端 - **框架**: Spring Boot 2.7.18 - **数据库**: MySQL 5.6+ - **ORM**: MyBatis Plus 3.5.3.1 - **安全**: Spring Security + JWT - **Java版本**: Java 11 ### 前端 - **框架**: Vue 3.3.4 - **UI组件**: Element Plus 2.3.8 - **构建工具**: Vite 4.4.5 - **状态管理**: Pinia 2.1.6 - **HTTP客户端
125 4
基于springboot+vue开发的会议预约管理系统
|
5月前
|
JavaScript 前端开发 Java
制造业ERP源码,工厂ERP管理系统,前端框架:Vue,后端框架:SpringBoot
这是一套基于SpringBoot+Vue技术栈开发的ERP企业管理系统,采用Java语言与vscode工具。系统涵盖采购/销售、出入库、生产、品质管理等功能,整合客户与供应商数据,支持在线协同和业务全流程管控。同时提供主数据管理、权限控制、工作流审批、报表自定义及打印、在线报表开发和自定义表单功能,助力企业实现高效自动化管理,并通过UniAPP实现移动端支持,满足多场景应用需求。
464 1