Java 入门指南:使用 Docker 创建容器化 Spring Boot 应用程序

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 接下来,我们需要创建一个 Dockerfile,其中包含了构建 Java 映像所需的指令。在 Spring Boot 项目的根目录下创建一个名为 Dockerfile 的文件,并将以下内容添加到其中:

Docker 已经成为现代应用程序开发和部署的不可或缺的一部分。它使开发人员能够在不同环境中轻松部署应用程序,确保一致性和可重复性。本入门指南将教您如何使用 Docker 容器化一个简单的 Spring Boot 应用程序。您将学习如何使用 Maven 克隆和运行 Spring Boot 应用程序,创建一个包含构建 Java 映像所需指令的新 Dockerfile,将生成的映像作为容器运行,设置本地开发环境以连接到容器中的数据库,并使用 Docker Compose 运行 Spring Boot 应用程序。最后,我们还将使用 GitHub Actions 配置 CI/CD 管道以自动化构建和部署您的应用程序。


步骤 1: 准备工作

在开始之前,确保您已经安装了以下工具:


  • Docker:您需要在本地系统上安装 Docker。您可以从 Docker 官方网站 下载适合您操作系统的版本。


  • Maven:如果您尚未安装 Maven,可以在 Maven 官方网站 上找到安装说明。


  • Java 开发工具:您需要一个 Java 集成开发环境(IDE),如 Eclipse、IntelliJ IDEA 或 Visual Studio Code。


步骤 2: 克隆 Spring Boot 应用程序

首先,我们需要获取一个 Spring Boot 应用程序的源代码,以便后续容器化操作。您可以使用 Git 克隆一个示例项目,也可以使用您自己的 Spring Boot 项目。

# 使用 Git 克隆示例 Spring Boot 项目
git clone https://github.com/spring-projects/spring-petclinic.git
cd spring-petclinic

c95f2d954904a1b0e630bf3403e9ecf3_76dcbe780a3a4f3e93a64fd9ce3f229f.png

步骤 3: 创建 Dockerfile

接下来,我们需要创建一个 Dockerfile,其中包含了构建 Java 映像所需的指令。在 Spring Boot 项目的根目录下创建一个名为 Dockerfile 的文件,并将以下内容添加到其中:


# 使用官方的 OpenJDK 11 基础映像
FROM openjdk:11-jre-slim
# 在容器中创建一个目录来存放应用程序文件
RUN mkdir /app
# 复制应用程序 JAR 文件到容器中的 /app 目录
COPY target/*.jar /app/app.jar
# 指定容器启动时要执行的命令
CMD ["java", "-jar", "/app/app.jar"]


这个 Dockerfile 基于官方的 OpenJDK 11 基础映像,将 Spring Boot 应用程序的 JAR 文件复制到容器中,并定义了容器启动时要执行的命令。

0c72e66af59a0829dac3ec31c24282ae_a341f96e29934dc795beee3bb4f1408b.png

步骤 4: 构建 Docker 映像

现在,我们可以使用 Docker 命令构建我们的 Docker 映像。在 Spring Boot 项目的根目录中执行以下命令:


docker build -t spring-boot-app .


这将使用我们的 Dockerfile 构建一个名为 spring-boot-app 的 Docker 映像。确保在命令后面有一个 .,表示使用当前目录中的 Dockerfile。


8fc49af26e91345be5607029726f3645_a704462ff40744b8b02dcde67e8d7c6e.png

步骤 5: 运行容器

一旦 Docker 映像构建完成,我们可以使用 Docker 运行容器。在命令行中执行以下命令:


docker run -p 8080:8080 spring-boot-app


这将在容器内运行我们的 Spring Boot 应用程序,并将容器的端口 8080 映射到主机的端口 8080。您可以通过浏览器访问 http://localhost:8080 来查看应用程序是否正常运行。

步骤 6: 链接到本地数据库

通常情况下,应用程序需要与数据库进行交互。


在容器化环境中,您可以链接到本地数据库或使用容器化的数据库。


如果您希望链接到本地数据库,请确保您的 Spring Boot 应用程序的配置文件中已经正确配置了数据库连接信息。容器内的应用程序可以访问主机上的本地数据库,因为它们共享相同的网络。


步骤 7: 使用 Docker Compose 运行多个容器

在实际应用中,通常需要多个容器来支持不同的服务和组件。Docker Compose 是一个用于定义和运行多个 Docker 容器的工具。


您可以创建一个名为 docker-compose.yml 的 Docker Compose 配置文件,其中定义了应用程序的各个服务、网络和卷。以下是一个示例 docker-compose.yml 文件:


version: '3'
services:
  app:
    build: .
    ports:
      - "8080:8080"
  database:
    image: mysql:latest
    environment:
      MYSQL_ROOT_PASSWORD: password
      MYSQL_DATABASE: mydb


这个示例使用 Docker Compose 同时运行我们的 Spring Boot 应用程序和一个 MySQL 数据库容器。

b9762509a2623ccc69aab7aae5afd59a_ce4289290d4045079a8c314c67712b5a.png


步骤 8: 设置 CI/CD 管道

最后,为了自动化构建和部署您的应用程序,您可以使用 CI/CD 管道。GitHub Actions 是一个流行的 CI/CD 工具,可以与 Docker 结合使用,以实现持续集成和持续交付。


通过在项目的 GitHub 存储库中配置 GitHub Actions,您可以设置自动构建 Docker 映像、运行测试、部署应用程序到生产环境等任务。

77e9218f4629bd135902684765bd5fd3_f3553195bb334bb9ae9a6fa528a05d2c.png


结论

Docker 提供了一种强大的方式来容器化应用程序,使其在不同环境中运行一致性和可重复性。本指南介绍了如何将一个简单的 Spring Boot 应用程序容器化,以及如何使用 Docker Compose 运行多个容器来支持应用程序的不同服务。此外,GitHub Actions 的集成使自动化构建和部署变得更加容易。希望这个指南对您的 Docker 容器化旅程有所帮助,让您更轻松地管理和部署应用程序。

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
4天前
|
Kubernetes Linux 开发者
深入探索容器化技术——Docker 的实战应用
深入探索容器化技术——Docker 的实战应用
26 5
|
6天前
|
关系型数据库 MySQL Java
【Docker最新版教程】一文带你快速入门Docker常见用法,实现容器编排和自动化部署上线项目
Docker快速入门到项目部署,MySQL部署+Nginx部署+docker自定义镜像+docker网络+DockerCompose项目实战一文搞定!
|
5天前
|
开发者 Docker Python
从零开始:使用Docker容器化你的Python Web应用
从零开始:使用Docker容器化你的Python Web应用
15 1
|
7天前
|
存储 安全 Java
Java多线程编程中的并发容器:深入解析与实战应用####
在本文中,我们将探讨Java多线程编程中的一个核心话题——并发容器。不同于传统单一线程环境下的数据结构,并发容器专为多线程场景设计,确保数据访问的线程安全性和高效性。我们将从基础概念出发,逐步深入到`java.util.concurrent`包下的核心并发容器实现,如`ConcurrentHashMap`、`CopyOnWriteArrayList`以及`BlockingQueue`等,通过实例代码演示其使用方法,并分析它们背后的设计原理与适用场景。无论你是Java并发编程的初学者还是希望深化理解的开发者,本文都将为你提供有价值的见解与实践指导。 --- ####
|
8天前
|
运维 Kubernetes Cloud Native
云原生技术入门:Kubernetes和Docker的协同工作
【10月更文挑战第43天】在云计算时代,云原生技术成为推动现代软件部署和运行的关键力量。本篇文章将带你了解云原生的基本概念,重点探讨Kubernetes和Docker如何协同工作以支持容器化应用的生命周期管理。通过实际代码示例,我们将展示如何在Kubernetes集群中部署和管理Docker容器,从而为初学者提供一条清晰的学习路径。
|
1天前
|
Kubernetes Linux 开发者
深入探索容器化技术——Docker 的实战应用
深入探索容器化技术——Docker 的实战应用
14 0
|
2天前
|
存储 Cloud Native 开发者
深入探索容器化技术——Docker的实战应用
深入探索容器化技术——Docker的实战应用
9 0
|
3天前
|
JavaScript Linux 持续交付
深入探索容器化技术——Docker 的实战应用
深入探索容器化技术——Docker 的实战应用
19 0
|
9天前
|
Kubernetes 监控 安全
容器化技术:Docker与Kubernetes的实战应用
容器化技术:Docker与Kubernetes的实战应用
|
10天前
|
Java Docker 微服务
利用Docker容器化部署Spring Boot应用
利用Docker容器化部署Spring Boot应用
36 0
下一篇
无影云桌面