当前位置: 首页 > news >正文

使用 Docker 搭建 Java(SpringBoot)开发环境——AI教你学Docker

使用 Docker 搭建 Java(SpringBoot)开发环境

本指南介绍如何用 Docker 和 Docker Compose 构建典型的 Java(Spring Boot)应用开发环境,并集成常用中间件服务,如 MySQL、Redis、Kafka。适用于个人开发、团队协作与一体化本地测试。

一、目录结构建议

project-root/
├── app/                   # SpringBoot 应用源码目录
│   ├── Dockerfile
│   └── ...
├── docker-compose.yml     # Compose 主配置
├── mysql-data/            # MySQL 数据卷(本地开发用,加入 .gitignore)
├── redis-data/            # Redis 数据卷(同上)
└── .env                   # 环境变量配置(如端口、密码,勿提交敏感数据)

二、SpringBoot 应用 Dockerfile 示例

# app/Dockerfile
FROM eclipse-temurin:17-jdk-alpine
WORKDIR /app
COPY target/*.jar app.jar
EXPOSE 8080
ENTRYPOINT ["java", "-jar", "app.jar"]
  • 注意:构建镜像前需本地或CI中打包 mvn clean package -DskipTests 生成 jar 包。

三、docker-compose.yml 配置详解

version: "3.9"
services:app:build:context: ./appdockerfile: Dockerfilecontainer_name: springboot-appports:- "8080:8080"environment:SPRING_DATASOURCE_URL: jdbc:mysql://mysql:3306/devdb?useSSL=false&allowPublicKeyRetrieval=true&serverTimezone=UTCSPRING_DATASOURCE_USERNAME: devuserSPRING_DATASOURCE_PASSWORD: devpassSPRING_REDIS_HOST: redisSPRING_REDIS_PORT: 6379SPRING_KAFKA_BOOTSTRAP_SERVERS: kafka:9092depends_on:- mysql- redis- kafkamysql:image: mysql:8.0container_name: mysqlrestart: alwaysports:- "3306:3306"environment:MYSQL_ROOT_PASSWORD: rootpassMYSQL_DATABASE: devdbMYSQL_USER: devuserMYSQL_PASSWORD: devpassvolumes:- ./mysql-data:/var/lib/mysqlredis:image: redis:7container_name: redisrestart: alwaysports:- "6379:6379"volumes:- ./redis-data:/datazookeeper:image: bitnami/zookeeper:3.8container_name: zookeeperenvironment:- ALLOW_ANONYMOUS_LOGIN=yesports:- "2181:2181"kafka:image: bitnami/kafka:3.5container_name: kafkadepends_on:- zookeeperenvironment:KAFKA_BROKER_ID: 1KAFKA_CFG_ZOOKEEPER_CONNECT: zookeeper:2181KAFKA_CFG_LISTENERS: PLAINTEXT://:9092KAFKA_CFG_ADVERTISED_LISTENERS: PLAINTEXT://localhost:9092ALLOW_PLAINTEXT_LISTENER: "yes"ports:- "9092:9092"

说明

  • depends_on 保证应用启动顺序,但不保证服务已完全就绪,生产建议配合 healthcheck。
  • 各服务通过服务名(如 mysql、redis、kafka)互联,SpringBoot 只需用服务名作为 host。

四、运行流程

  1. 构建 SpringBoot 应用 jar 包
    cd app
    mvn clean package -DskipTests
    cd ..
    
  2. 启动所有服务
    docker compose up -d --build
    
  3. 查看服务状态
    docker compose ps
    
  4. 查看应用日志
    docker compose logs -f app
    
  5. 访问应用
    • 浏览器或 Postman 访问 http://localhost:8080

五、常见注意事项

  1. 端口冲突

    • 如本地已有 MySQL/Redis 服务,需调整 compose 暴露端口或关闭本地服务。
  2. 数据持久化

    • 挂载本地目录(如 mysql-data/、redis-data/)避免容器重启后数据丢失。
    • 不建议将这些数据卷提交进版本控制(加入 .gitignore)。
  3. 环境变量与配置安全

    • .env 文件可集中管理端口、密码等,生产环境应避免明文密码。
    • 不要把敏感数据上传到代码仓库。
  4. Kafka 配置

    • Kafka 依赖 Zookeeper,需保证 Zookeeper 先启动。
    • 默认配置适合开发调试,生产建议单独网络、鉴权等更严格配置。
  5. 服务连接

    • SpringBoot 的配置中数据库、Redis、Kafka 的 host 必须与 Compose 服务名一致。
    • 配置样例(application.yml):
      spring:datasource:url: jdbc:mysql://mysql:3306/devdb?...username: devuserpassword: devpassredis:host: redisport: 6379kafka:bootstrap-servers: kafka:9092
      
  6. 热部署开发

    • 推荐用 IDE 的远程调试、或挂载源码进容器实现热部署(可选)。
    • 也可开发时本地运行 SpringBoot,仅用 Docker 启动中间件。
  7. 初次启动慢

    • 首次启动需拉取镜像,视网速可能较慢,后续会提升。
    • 如需要更多中间件(如 MongoDB、RabbitMQ),可按需添加 service。

六、推荐扩展

  • 数据库初始化脚本:可将 sql 脚本挂载到 /docker-entrypoint-initdb.d/(MySQL)。
  • 自定义网络:如需与其他项目互通,可用 networks 字段自定义网络。
  • 健康检查:为关键服务添加 healthcheck,提升健壮性。
  • 分环境配置:用不同 docker-compose.override.yml 管理开发/测试/生产环境差异。

七、参考资料

  • Spring Boot 官方文档
  • Docker Compose 官方文档
  • Bitnami Kafka 镜像说明
  • MySQL Docker 镜像说明
  • Redis Docker 镜像说明
http://www.dtcms.com/a/269665.html

相关文章:

  • 零基础|宝塔面板|frp内网穿透|esp32cam远程访问|微信小程序
  • 电商业务是如何防护DDoS攻击的?
  • 2563、统计公平数对的数目
  • ElasticSearch集群状态查询及_cat 命令详解
  • JDBC 获取新增行主键值详解
  • 向量与向量组的线性相关性 线性代数
  • 【Android】搭配安卓环境及设备连接
  • 17-C#的socket通信TCP-1
  • 静态路由实验以及核心原理
  • 计算机网络第九章——数据链路层《局域网》
  • 裂变时刻:全球关税重构下的券商交易系统跃迁路线图(2025-2027)
  • 3.springboot2使用selenium(java8)
  • 多模态大语言模型arxiv论文略读(152)
  • 【LeetCode 热题 100】142. 环形链表 II——快慢指针
  • X00193-MASAC强化学习算法的多无人机协同路径规划
  • 一文讲清楚React中的key值作用与原理
  • PostgreSQL复制技术全解析:从物理复制到逻辑复制的实践指南
  • Ollama+OpenWebUI 0.42+0.3.35 最新版一键安装教程,解决手动更新失败问题
  • Swift 解 LeetCode 321:拼接两个数组中的最大数,贪心 + 合并全解析
  • WebSocket实战:打造实时在线聊天室
  • NealFun安卓版:创意无限,娱乐至上
  • 学习设计模式《十七》——状态模式
  • 干货分享 | TSMaster DBC编辑器操作指南:功能详解+实战示例
  • Spring Boot 事务失效问题详解:原因、场景与解决方案
  • Spring Boot + Easy Excel 自定义复杂样式导入导出
  • [Swarm] Result对象 | 智能体切换 | Response对象 | muduo review
  • Android.mk拷贝文件、文件夹
  • 5 种备份和恢复安卓短信的方法
  • 音频主动降噪技术
  • 快手播放量是什么意思?浏览量等于播放量吗