广告
返回顶部
首页 > 资讯 > 数据库 >docker-compose启动springboot项目连接mysql问题
  • 459
分享到

docker-compose启动springboot项目连接mysql问题

摘要

目录1、数据库配置2、打包3、编写SpringBoot的Dockerfile4、编写docker-compose.yml5、启动总结开发工具:idea 1、数据库配置 注意:Mysql配置使用的是docker中的镜像名,

开发工具idea

1、数据库配置

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

如下:

docker-compose启动springboot项目连接mysql问题

2、打包

这里使用idea自带Maven打包(jar

docker-compose启动springboot项目连接mysql问题

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问题

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

您可能感兴趣的文档:

--结束END--

本文标题: docker-compose启动springboot项目连接mysql问题

本文链接: https://www.lsjlt.com/news/200034.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作