docker-compose 启动springboot 项目连接mysql

开发工具:idea

1、数据库配置

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

docker-compose 启动springboot 项目连接mysql_第1张图片

2、打包

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

docker-compose 启动springboot 项目连接mysql_第2张图片 

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_第3张图片

访问结果如下:

docker-compose 启动springboot 项目连接mysql_第4张图片

你可能感兴趣的:(docker)