实操-docker-compose 部署一个springboot+mysql的项目

docker-compose 部署一个springboot+mysql的项目

1: 准备Spring Boot应用

确保应用能够正常运行,并打成jar包

2: 创建Dockerfile

复制代码
# 使用官方Spring Boot作为父镜像  
FROM openjdk:8 

# 将jar包添加到容器中并更名为app.jar 
# JAR_FILE变量的路径与你的jar包实际位置相匹配。 
ARG JAR_FILE=target/*.jar  
COPY ${JAR_FILE} app.jar  

# 容器启动时运行jar包  
ENTRYPOINT ["java","-jar","/app.jar"]  

# 暴露端口  
EXPOSE 8080

3: 创建docker-compose.yml

复制代码
version: '3.8'  

services:  
db:  
    image: mysql:8.0  
    container_name: mysql-db  
    environment:  
    MYSQL_ROOT_PASSWORD: root  
    MYSQL_DATABASE: yourdatabase  
    MYSQL_USER: user  
    MYSQL_PASSWORD: password  
    volumes:  
    - db-data:/var/lib/mysql  
    # 容器的初始化过程中执行一个SQL脚本,假设你的SQL文件在当前目录下的init文件夹中
    - ./init:/docker-entrypoint-initdb.d/ 
    ports:  
    - "3306:3306"  

app:  
    build:  
    context: .  
    dockerfile: Dockerfile  
    image: your-spring-boot-app  
    container_name: spring-boot-app  
    ports:  
    - "8080:8080"  
    depends_on:  
    - db  
    environment:  
    SPRING_DATASOURCE_URL: jdbc:mysql://mysql-db:3306/yourdatabase?useSSL=false&allowPublicKeyRetrieval=true&serverTimezone=UTC  
    SPRING_DATASOURCE_USERNAME: user  
    SPRING_DATASOURCE_PASSWORD: password  
    volumes:  
    - app-data:/app/data
    - ./logs:/app/logs 


volumes:  
    db-data:  
    app-data:  
    logs:

4: 构建和运行

复制代码
# 构建
docker-compose build

# 不使用缓存构建
docker-compose build --no-cache

# 启动服务
docker-compose up

# 后台启动
docker-compose up -d

# 停止
docker-compose stop

# 重新启动
docker-compose restart

# 查看所有docker-compose 构建的服务
docker-compose ps -a

# 查看日志
docker-compose logs  

# 或者查看特定服务的日志  
docker-compose logs <服务名称>
相关推荐
l1t5 小时前
用docker安装测试crate数据库
数据库·docker·容器·cratedb
身如柳絮随风扬5 小时前
MySQL核心知识
数据库·mysql
SuniaWang5 小时前
《Spring AI + 大模型全栈实战》学习手册系列 · 专题六:《Vue3 前端开发实战:打造企业级 RAG 问答界面》
java·前端·人工智能·spring boot·后端·spring·架构
韩立学长5 小时前
Springboot校园跑腿业务系统0b7amk02(程序、源码、数据库、调试部署方案及开发环境)系统界面展示及获取方式置于文档末尾,可供参考。
数据库·spring boot·后端
sheji34165 小时前
【开题答辩全过程】以 基于springboot的扶贫系统为例,包含答辩的问题和答案
java·spring boot·后端
551只玄猫6 小时前
【数据库原理 实验报告1】创建和管理数据库
数据库·sql·学习·mysql·课程设计·实验报告·数据库原理
q5431470876 小时前
MySQL SQL100道基础练习题
数据库·mysql
zhoupenghui1686 小时前
mysql 中如果条件where中有or,则要求or两边的字段都必须有索引,否则不能用到索引, 为什么?
数据库·mysql·索引
枕书6 小时前
实战记录:如何使用 Docker 一键部署长亭 PandaWiki 智能知识库
运维·docker·容器
eggwyw7 小时前
完美解决phpstudy安装后mysql无法启动
数据库·mysql