Docker Compose部署Springboot+Mysql项目

声明:本文CSDN作者原创投稿文章,未经许可禁止任何形式的转载,原文链接

在上一篇文章Spring Boot(Maven)+Docker打包中,我们实现了将Springboot项目源代码一键打包部署为Docker服务。

上文中,我们的Springboot项目如果要与数据库的连接,就必须连接公网IP来使用,本文将会把Springboot+Mysql进行一键部署,开箱即用。

本文应用场景是:web服务的单机部署。

前提

Spring Boot项目已可使用Maven打包为jar文件,并可通过java -jar example-0.0.1-SNAPSHOT.jar启动此文件。

必须安装Docker,Docker Compose。

操作

第一步:在项目根目录下创建文件Dockerfile,内容如下,本文项目使用的是jdk11,开放8086端口。注意:需要将下文的两处example-0.0.1-SNAPSHOT改为你的项目的名字。

FROM maven:3.8.3-openjdk-11 AS MAVEN_BUILD
COPY settings.xml /usr/share/maven/conf/settings.xml
COPY pom.xml /build/
COPY src /build/src/
WORKDIR /build/
RUN mvn package

FROM maslick/minimalka:jdk11
COPY --from=MAVEN_BUILD /build/target/example-0.0.1-SNAPSHOT.jar /app/
RUN mkdir -p "/app/static/images/upload"
EXPOSE 8086
ENTRYPOINT ["java","-jar","/app/example-0.0.1-SNAPSHOT.jar"]

你会注意到Dockerfile与上篇文章仅有一处不同,即多了一行RUN mkdir -p "/app/static/images/upload",这是因为我的后端项目接收存储了一些用户上传的文件,我使用Volume对文件内容进行了持久化。

第二步:创建settings.xml文件,替换掉Maven官方源,使用国内源,文件内容与上篇文章相同。

第三步:在项目根目录下创建文件docker-compose.yml,内容如下:

version: '3'
services:
  web:
    build: .
    container_name: web-server
    restart: always
    volumes:
      - imagedata:/app/static/images/upload
    ports:
      - "8086:8086"
    depends_on:
      - mysql
  mysql:
    image: mysql:8.0.26
    container_name: mysql
    restart: always
    volumes:
      - dbdata:/var/lib/mysql
    environment:
      MYSQL_DATABASE: webserver #创建一个初始的空数据库,名为webserver
      MYSQL_ROOT_USER: root #root用户
      MYSQL_ROOT_PASSWORD: QWEasd123 #root密码
      MYSQL_ROOT_HOST: '%' 
      TZ: Asia/Shanghai #时区
volumes:
  dbdata:
  imagedata:

docker-compose.yml的解释如下:

  • 创建了web和mysql两个服务,并分别声明了他们的容器名称。
  • 创建了dbdata和imagedata两个卷,用来存储数据库数据和用户上传的文件。
  • 将imagedata卷映射到了web服务的/app/static/images/upload目录;dbdata卷映射到了mysql服务的/var/lib/mysql目录,这是mysql的默认数据目录。
  • web服务的8086端口映射到了主机的8086端口。

对于声明在同一个docker-compose.yml中的服务,不需要新建网络,他们便可以通过域名互相通信,所以我们也没有创建新网络。

第四步:修改Springboot配置文件中的数据源,如下:

spring.datasource.url=jdbc:mysql://mysql:3306/webserver?useUnicode=true&characterEncoding=utf8&useSSL=false&allowPublicKeyRetrieval=true
spring.datasource.username=root
spring.datasource.password=QWEasd123

第五步:部署运行。

在项目根目录下,执行如下命令,

docker-compose up

如果你想在后台执行该服务可以加上 -d 参数:

docker-compose up -d

等待项目构建运行即可!

最后

​ 项目构建运行完成之后,通过docker images会发现除了多出了一个我们刚构建的项目镜像之外,额外多了两个镜像maven:3.8.3-openjdk-11minimalka:jdk11,这是构建我们自己的镜像时必须要用的基础镜像,如果以后还需要再此构建项目,可以将这两个镜像保留,否则可以将其删除。

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要使用docker部署springboot+MySQL项目,可以按照以下步骤进行操作: 1. 编写Dockerfile文件,指定基础镜像、安装JDK和MySQL等依赖,将项目打包成jar包并复制到镜像中。 ```dockerfile FROM openjdk:11-jdk-slim VOLUME /tmp ARG JAR_FILE=target/*.jar COPY ${JAR_FILE} app.jar RUN mkdir -p /var/lib/mysql RUN apt-get update && apt-get install -y mysql-server RUN echo "bind-address = 0.0.0.0" >> /etc/mysql/mysql.conf.d/mysqld.cnf RUN service mysql start && \ mysql -uroot -e "CREATE DATABASE db_name" && \ mysql -uroot -e "CREATE USER 'username'@'%' IDENTIFIED BY 'password'" && \ mysql -uroot -e "GRANT ALL PRIVILEGES ON db_name.* TO 'username'@'%';" EXPOSE 8080 ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"] ``` 2. 构建镜像 在Dockerfile的目录下执行以下命令: ```shell docker build -t springboot-mysql . ``` 这里将镜像命名为springboot-mysql。 3. 运行容器 执行以下命令运行容器: ```shell docker run -d -p 8080:8080 -p 3306:3306 -e MYSQL_ROOT_PASSWORD=password -e MYSQL_DATABASE=db_name -e MYSQL_USER=username -e MYSQL_PASSWORD=password springboot-mysql ``` 这里将容器的8080端口映射到主机的8080端口,3306端口映射到主机的3306端口,并指定MySQL的root密码、数据库名、用户名和密码。 4. 访问应用 在浏览器中访问http://localhost:8080,即可访问应用。 注意:如果使用docker-compose进行部署,可以在docker-compose.yml文件中指定MySQL的配置,更加方便和灵活。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值