我是靠谱客的博主 复杂巨人,最近开发中收集的这篇文章主要介绍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所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(35)

评论列表共有 0 条评论

立即
投稿
返回
顶部