docker-compose启动springboot项目连接mysql问题怎么解决

2023-05-15,,

本篇内容主要讲解“docker-compose启动springboot项目连接mysql问题怎么解决”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“docker-compose启动springboot项目连接mysql问题怎么解决”吧!

开发工具:idea

1、数据库配置

注意:mysql配置使用的是docker中的镜像名,不是ip地址

如下:

2、打包

这里使用idea自带maven打包(jar)

3、编写springboot的dockerfile

(我这里为ssm_dockerfile),与上一步打包好的jar包放同一目录。

ADD的jar包是上一步打包好的jar包名,后面可以起别名

如下:

FROM frolvlad/alpine-oraclejdk8:slim
VOLUME /tmp
ADD ssmdemo-0.0.1-SNAPSHOT.jar ssm.jar
RUN sh -c 'touch /ssm.jar'
ENV JAVA_OPTS=""
ENTRYPOINT [ "sh", "-c", "java $JAVA_OPTS -Djava.security.egd=file:/dev/./urandom -jar /ssm.jar" ]

4、编写docker-compose.yml

与jar包和dockerfile放同一目录。

如下:

version : '2'
 
services:
 
  learn2:
    build:
      context: .
      dockerfile: ssm_dockerfile
    ports:
      - "8080:8080"
    volumes:
      - .:/vol/development
    depends_on:
      - c_mysql
 
  c_mysql:
    image: docker.io/mysql:5
    ports:
      - "3306:3306"
    environment:
      MYSQL_DATABASE: blogdb
      MYSQL_ROOT_PASSWORD: root
      MYSQL_ROOT_HOST: '%'
    restart: always

解释:

springboot工程的配置,context,dockerfile对应dockerfile的位置,ports端口映射,volumes表示将物理机的当前目录映射到docker虚拟机/vol/development里面,depends_on依赖mysql 控制容器启动顺序让mysql先启。

mysql的配置,直接从docker hub下载,image 对应的就是docker hub的镜像, ports 对应端口映射,与docker -p差不多一个意思,environment 配置mysql创建的库,root的密码,还有允许访问的IP配为%,restart 每次都重新启动。

5、启动

在docker-compose.yml所在目录下运行 docker-compose up命令,如果后台运行加一个-d,会发现mysql先从docker hub下载并启动,然后启动springboot工程。

访问结果如下:

到此,相信大家对“docker-compose启动springboot项目连接mysql问题怎么解决”有了更深的了解,不妨来实际操作一番吧!这里是本站网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

《docker-compose启动springboot项目连接mysql问题怎么解决.doc》

下载本文的Word格式文档,以方便收藏与打印。