Docker compose部署SpringBoot项目连接MySQL及遇到的坑

时间:2022-03-06 16:46:51

前面使用docker简单部署了下SpringBoot项目并介绍了什么是Dockerfile,如果是镜像比较多的情况下如何一键交付呢?Docker-compose!,理解了Docker-compose后面学习K8s就会好理解一些

一、安装docker-compose

环境Centos7

//下载docker-compose
curl -L "https://get.daocloud.io/docker/compose/releases/download/1.27.3/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose

//为文件增加可执行权限,要不然root用户也没有权限
chmod +x /usr/local/bin/docker-compose

//查看是否安装成功
[root@SJS local]# docker-compose --version
docker-compose version 1.27.3, build 4092ae5d

常用命令

#构建、创建、启动相关容器
docker-compose up -d

#停止所有相关容器
docker-compose stop

#列出所有容器信息
docker-compose ps

二、部署的步骤

  1. 1.使用Dockerfile定义应用程序环境,一般需要修改初始镜像行为时才需要使用
  2. 2.使用docker-compose.yml定义要部署的应用程序服务,以便执行脚本一次性部署
  3. 3.使用docker-compose up命令将所有应用服务一次性部署起来

三、部署SpringBoot项目

项目整体

Docker compose部署SpringBoot项目连接MySQL及遇到的坑

1.编写Dockerfile

FROM java:8
# 在docker容器中自建容器卷,用于数据保存和持久化工作
VOLUME /tmp
#用于复制文件并解压缩(COPY不能解压缩)
#将当前的redpacket-backend-1.0.0-SNAPSHOT.jar复制到docker容器根目录下
ADD redpacket-backend-1.0.0-SNAPSHOT.jar app.jar
#运行过程中创建一个app.jar文件
RUN sh -c "touch /app.jar"
ENV JAVA_OPTS=""
#执行传入的参数的linux命令,启动jar包
#不同CMD的是:多个CMD命令只能是最后一个生效,CMD会被docker run之后的参数替换
#ENTRYPOINT 执行的命令会追加不会覆盖
ENTRYPOINT [ "sh", "-c", "java $JAVA_OPTS -Djava.security.egd=file:/dev/./urandom -jar /app.jar" ]

2.编写docker-compose.yml文件

该文件主要分为三个组成部分

工程:整个yml文件就是一个工程
服务:services节点下即为服务
容器:服务下为容器

version: "3.8"
services:
  #mysql服务名字
  mysql:
    #使用的镜像
    image: mysql:5.7
    command: --default-authentication-plugin=mysql_native_password
    ports:
      - 3306:3306
    environment:
      MYSQL_ROOT_HOST: "%"
      MYSQL_ROOT_PASSWORD: "123456"
      MYSQL_ALLOW_EMPTY_PASSWORD: "no"
      MYSQL_DATABASE: "redpacket"
      MYSQL_USER: "root"
      MYSQL_PASSWORD: "123456"
    #需要挂载的文件卷
    volumes:
      - /mydata/mysql/data:/var/lib/mysql
      - /mydata/mysql/log:/var/log/mysql
      - /mydata/mysql/conf:/etc/mysql
    restart: always
    networks:
      - test_network
  #SpringBoot项目服务
  redpacket:
    container_name: redpacket
    #构建指定目录下的Dockerfile
    build:
      context: .
      dockerfile: Dockerfile
    depends_on:
      - mysql
    ports:
      - "8090:8090"
    restart: always
    networks:
      - test_network
networks:
  test_network:

3.注意修改yml文件链接名字

Docker compose部署SpringBoot项目连接MySQL及遇到的坑

4.一键启动项目

将项目的dockerfile、docker-compose.yml、jar包放到同一目录下,使用docker-compose启动即可

Docker compose部署SpringBoot项目连接MySQL及遇到的坑

就成功了

Docker compose部署SpringBoot项目连接MySQL及遇到的坑

四、踩的坑

如果在使用的过程中修改了Dockerfile,一定要把之前的镜像删掉!,要不然即使运行docker-compose up命令能成功,也不会重新构建之前的镜像只是重新创建一个容器。

参考文章:

https://mp.weixin.qq.com/s/iMl9bJ4SxUsNHBbiS5VUcw

https://docs.docker.com/compose/env-file/

https://blog.csdn.net/u011943534/article/details/81392993

到此这篇关于Docker compose部署SpringBoot项目连接MySQL的文章就介绍到这了,更多相关Docker compose部署SpringBoot项目内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/shang_0122/article/details/120473681