百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程字典 > 正文

如何将一个Spring Boot 应用打包到Docker镜像中?

toyiye 2024-07-09 23:02 12 浏览 0 评论

有这样一个需求,将一个SpringBoot的应用打包到Docker镜像中,并且这个SpringBoot的应用还需要用到MySQL、Redis等持久化工具,最好是能够在项目启动的时候自己执行SQL语句到数据库中。我们应该如何实现这个需求呢?

下面我们就来看看如何将一个Spring Boot应用与MySQL、Redis等持久化服务一起打包到Docker镜像中,然后运行并启动项目

编写Dockerfile

首先需要我们在SpringBoot项目根目录下创建一个Dockerfile的文件,用于定义Docker镜像的构建过程,示例内容如下所示。

# 使用基础镜像,这里以OpenJDK 11为例
FROM openjdk:11-jre-slim

# 设置工作目录
WORKDIR /app

# 复制编译好的Spring Boot JAR文件到镜像中
COPY target/my-application.jar /app

# 复制SQL脚本到镜像中
COPY db-scripts/initialize.sql /docker-entrypoint-initdb.d/

# 暴露应用端口
EXPOSE 8080

# 定义启动命令
CMD ["java", "-jar", "my-application.jar"]

在上面的例子中,我们将数据库SQL脚本复制到了镜像中,然后将其放在MySQL容器初始化脚本的/docker-entrypoint-initdb.d/ 中。这样,在MySQL容器启动时,会自动执行该SQL脚本,来进行数据库的初始化操作。

编写Docker Compose文件

接下来就可以使用Docker Compose来进行管理了,我们创建一个名为docker-compose.yml 的文件,用于定义Spring Boot应用、MySQL、Redis等服务的配置和链接关系,如下所示。

version: '3'
services:
  my-application:
    build: .
    ports:
      - "8080:8080"
    depends_on:
      - mysql
      - redis
    environment:
      SPRING_DATASOURCE_URL: jdbc:mysql://mysql:3306/my_database
      SPRING_DATASOURCE_USERNAME: root
      SPRING_DATASOURCE_PASSWORD: password
      SPRING_REDIS_HOST: redis
  mysql:
    image: mysql:latest
    ports:
      - "3306:3306"
    environment:
      MYSQL_ROOT_PASSWORD: password
      MYSQL_DATABASE: my_database
  redis:
    image: redis:latest
    ports:
      - "6379:6379"

在这个文件中宏,我们定义了应用服务、数据库服务、Redis缓存服务三个服务,my-applicationmysqlredis。其中,my-application服务是用了上一步中构建的Docker镜像服务,而是指定了依赖于mysqlredis服务,并设置了Spring Boot应用与MySQL、Redis的连接参数。

编写SQL脚本

由于我们需要对数据库进行初始化操作,所以需要在Spring Boot项目的根目录下创建一个名为 db-scripts 的目录,并在其中编写初始化数据库的SQL脚本,例如 initialize.sql

构建并运行Docker容器

接下来我们就可以通过Docker Compose命令行工具来构建并且运行Docker容器了,如下所示。

docker-compose up --build

通过上面的这些操作,我们就可以完成构建和启动包含Spring Boot应用、MySQL、Redis等服务的Docker容器,并在MySQL容器启动时自动执行初始化脚本。

接下来我们可以继续完善Docker Compose文件,为其添加上MySQL和Redis的持久化配置以及SpringBoot应用与MySQL和Redis的连接信息等,如下所示。

version: '3'
services:
  my-application:
    build: .
    ports:
      - "8080:8080"
    depends_on:
      - mysql
      - redis
    environment:
      SPRING_DATASOURCE_URL: jdbc:mysql://mysql:3306/my_database
      SPRING_DATASOURCE_USERNAME: root
      SPRING_DATASOURCE_PASSWORD: password
      SPRING_REDIS_HOST: redis
  mysql:
    image: mysql:latest
    ports:
      - "3306:3306"
    environment:
      MYSQL_ROOT_PASSWORD: password
      MYSQL_DATABASE: my_database
    volumes:
      - mysql-data:/var/lib/mysql
  redis:
    image: redis:latest
    ports:
      - "6379:6379"
    volumes:
      - redis-data:/data

volumes:
  mysql-data:
  redis-data:

在更新之后,我们在Docker Compose中添加了两个卷(volumes),分别用于持久化存储MySQL和Redis的数据。这样,即使Docker容器被停止或删除,数据仍然会保留在宿主机的卷中,从而实现数据的持久化。

此外,我们也修改了Spring Boot应用的连接配置,使其能够正确连接到MySQL和Redis容器,以及设置了MySQL的初始化脚本。

通过上面的步骤,我们就可以完成SpringBoot整合MySQL、Redis等的容器化部署了,相比较于我们通过传统的安装MySQL、Redis的服务这种操作的话,容器化部署更加方便快捷,可以快速实现环境切换等。

相关推荐

为何越来越多的编程语言使用JSON(为什么编程)

JSON是JavascriptObjectNotation的缩写,意思是Javascript对象表示法,是一种易于人类阅读和对编程友好的文本数据传递方法,是JavaScript语言规范定义的一个子...

何时在数据库中使用 JSON(数据库用json格式存储)

在本文中,您将了解何时应考虑将JSON数据类型添加到表中以及何时应避免使用它们。每天?分享?最新?软件?开发?,Devops,敏捷?,测试?以及?项目?管理?最新?,最热门?的?文章?,每天?花?...

MySQL 从零开始:05 数据类型(mysql数据类型有哪些,并举例)

前面的讲解中已经接触到了表的创建,表的创建是对字段的声明,比如:上述语句声明了字段的名称、类型、所占空间、默认值和是否可以为空等信息。其中的int、varchar、char和decimal都...

JSON对象花样进阶(json格式对象)

一、引言在现代Web开发中,JSON(JavaScriptObjectNotation)已经成为数据交换的标准格式。无论是从前端向后端发送数据,还是从后端接收数据,JSON都是不可或缺的一部分。...

深入理解 JSON 和 Form-data(json和formdata提交区别)

在讨论现代网络开发与API设计的语境下,理解客户端和服务器间如何有效且可靠地交换数据变得尤为关键。这里,特别值得关注的是两种主流数据格式:...

JSON 语法(json 语法 priority)

JSON语法是JavaScript语法的子集。JSON语法规则JSON语法是JavaScript对象表示法语法的子集。数据在名称/值对中数据由逗号分隔花括号保存对象方括号保存数组JS...

JSON语法详解(json的语法规则)

JSON语法规则JSON语法是JavaScript对象表示法语法的子集。数据在名称/值对中数据由逗号分隔大括号保存对象中括号保存数组注意:json的key是字符串,且必须是双引号,不能是单引号...

MySQL JSON数据类型操作(mysql的json)

概述mysql自5.7.8版本开始,就支持了json结构的数据存储和查询,这表明了mysql也在不断的学习和增加nosql数据库的有点。但mysql毕竟是关系型数据库,在处理json这种非结构化的数据...

JSON的数据模式(json数据格式示例)

像XML模式一样,JSON数据格式也有Schema,这是一个基于JSON格式的规范。JSON模式也以JSON格式编写。它用于验证JSON数据。JSON模式示例以下代码显示了基本的JSON模式。{"...

前端学习——JSON格式详解(后端json格式)

JSON(JavaScriptObjectNotation)是一种轻量级的数据交换格式。易于人阅读和编写。同时也易于机器解析和生成。它基于JavaScriptProgrammingLa...

什么是 JSON:详解 JSON 及其优势(什么叫json)

现在程序员还有谁不知道JSON吗?无论对于前端还是后端,JSON都是一种常见的数据格式。那么JSON到底是什么呢?JSON的定义...

PostgreSQL JSON 类型:处理结构化数据

PostgreSQL提供JSON类型,以存储结构化数据。JSON是一种开放的数据格式,可用于存储各种类型的值。什么是JSON类型?JSON类型表示JSON(JavaScriptO...

JavaScript:JSON、三种包装类(javascript 包)

JOSN:我们希望可以将一个对象在不同的语言中进行传递,以达到通信的目的,最佳方式就是将一个对象转换为字符串的形式JSON(JavaScriptObjectNotation)-JS的对象表示法...

Python数据分析 只要1分钟 教你玩转JSON 全程干货

Json简介:Json,全名JavaScriptObjectNotation,JSON(JavaScriptObjectNotation(记号、标记))是一种轻量级的数据交换格式。它基于J...

比较一下JSON与XML两种数据格式?(json和xml哪个好)

JSON(JavaScriptObjectNotation)和XML(eXtensibleMarkupLanguage)是在日常开发中比较常用的两种数据格式,它们主要的作用就是用来进行数据的传...

取消回复欢迎 发表评论:

请填写验证码