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

发布时间:2021-09-28 09:11:26 作者:柒染
来源:亿速云 阅读:297

这期内容当中小编将会给大家带来有关Docker compose部署SpringBoot项目连接MySQL及遇到的坑有哪些,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

一、安装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命令能成功,也不会重新构建之前的镜像只是重新创建一个容器。

上述就是小编为大家分享的Docker compose部署SpringBoot项目连接MySQL及遇到的坑有哪些了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注亿速云行业资讯频道。

推荐阅读:
  1. #IT明星不是梦#【1键部署神功】docker-compos
  2. Docker三剑客之docker-compose

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

docker-compose springboot mysql

上一篇:SpringBoot打jar包遇到的xml文件丢失该怎么解决

下一篇:Springboot2.X如何解决单点登陆

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》