0

0

在Java中如何使用Docker搭建开发环境_容器化环境解析

P粉602998670

P粉602998670

发布时间:2026-01-12 14:32:02

|

485人浏览过

|

来源于php中文网

原创

java项目docker化核心是运行时行为与宿主机一致:需调整本地路径、localhost硬编码、jvm参数;dockerfile注意java_home、entrypoint/cmd、jar路径;推荐eclipse-temurin镜像;配置须外部化,用docker-compose统一管理依赖服务及健康检查。

在java中如何使用docker搭建开发环境_容器化环境解析

Java项目用Docker运行,核心就三步:写好Dockerfile、构建镜像、启动容器

不是所有Java项目都适合直接扔进Docker——比如依赖本地文件系统路径、硬编码localhost:8080、或用System.setProperty动态改JVM参数的,不调整就跑不起来。关键不在“能不能打包”,而在“运行时行为是否和宿主机一致”。Dockerfile里最常出问题的是JAVA_HOME没设对、ENTRYPOINTCMD混用导致命令不执行、或者把target/*.jar COPY错了路径。

  • 推荐基础镜像用eclipse-temurin:17-jre-jammy(轻量、安全更新及时),别用openjdk:17-jdk-slim再自己装curlbash
  • COPY命令要确认jar包在构建上下文里存在,常见错误是mvn clean package没先跑,或者Dockerfile放在src/下却想COPY根目录的target/app.jar
  • 启动命令统一用ENTRYPOINT ["java", "-jar", "app.jar"],别写RUN java -jar app.jar——后者只在构建阶段执行一次

Spring Boot项目暴露端口和配置必须外部化,不能靠application.properties硬编码

容器里localhost指的是容器自身,不是宿主机。所以Spring Boot默认的server.port=8080只是容器内监听,必须加EXPOSE 8080并在docker run时用-p 8080:8080映射,否则宿主机curl不通。更麻烦的是数据库地址——如果application.yml里写死url: jdbc:mysql://localhost:3306/mydb,容器启动后连的是它自己的127.0.0.1,不是你本机或另一个MySQL容器。

  • spring.profiles.active=docker激活独立配置,把数据库host改成服务名,例如jdbc:mysql://mysql:3306/mydb
  • 通过docker run -e "SPRING_DATASOURCE_URL=jdbc:mysql://mysql:3306/mydb"覆盖配置,优先级高于yml文件
  • 避免在Dockerfile里用ENV SPRING_PROFILES_ACTIVE=docker——这会让镜像失去环境适应性,应由运行时决定

docker-compose.yml才是Java开发环境的实际入口,单个docker run不够用

一个典型Java后端至少需要应用容器 + 数据库 + Redis,靠记一堆docker run参数没法协作。这时候docker-compose.yml不是可选项,是必需品。容易被忽略的是网络模式和健康检查:default网络下容器名自动变成DNS名,但如果你写了network_mode: host,服务间就无法用名字通信;另外没配healthcheck的话,Spring Boot还没启动完,Nginx或前端容器可能就去调用了,结果502。

Android 开发者指南 第一部分:入门
Android 开发者指南 第一部分:入门

Android文档-开发者指南-第一部分:入门-中英文对照版 Android提供了丰富的应用程序框架,它允许您在Java语言环境中构建移动设备的创新应用程序和游戏。在左侧导航中列出的文档提供了有关如何使用Android的各种API来构建应用程序的详细信息。第一部分:Introduction(入门) 0、Introduction to Android(引进到Android) 1、Application Fundamentals(应用程序基础) 2、Device Compatibility(设备兼容性) 3、

下载
  • 数据库服务必须声明restart: unless-stopped,否则docker-compose up失败时MySQL退出,Java应用反复重试连接直到超时
  • Java服务的depends_on只控制启动顺序,不等MySQL真正ready,得配合healthcheckcondition: service_healthy
  • 卷映射volumes慎用于target/目录——宿主机和容器的编译输出冲突会导致类加载异常,建议只映射config/logs/
version: '3.8'
services:
  app:
    build: .
    ports: ["8080:8080"]
    environment:
      - SPRING_PROFILES_ACTIVE=docker
      - SPRING_DATASOURCE_URL=jdbc:mysql://mysql:3306/mydb
    depends_on:
      mysql:
        condition: service_healthy
    restart: on-failure
<p>mysql:
image: mysql:8.0
environment:</p><ul><li>MYSQL_ROOT_PASSWORD=root</li><li>MYSQL_DATABASE=mydb
healthcheck:
test: ["CMD", "mysqladmin", "ping", "-h", "localhost", "-u", "root", "-proot"]
timeout: 20s
retries: 10
volumes:</li><li>mysql-data:/var/lib/mysql</li></ul><p>volumes:
mysql-data:

Java容器化真正的难点不在打包,而在于运行时依赖的解耦——数据库地址、配置中心地址、文件存储路径、时区、JVM内存参数,这些全得从代码里拎出来,交给Docker或Compose管理。少改一行application.yml,多写一个docker-compose.override.yml,比硬编码可靠得多。

立即学习Java免费学习笔记(深入)”;

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

686

2023.06.20

MySQL创建存储过程
MySQL创建存储过程

存储程序可以分为存储过程和函数,MySQL中创建存储过程和函数使用的语句分别为CREATE PROCEDURE和CREATE FUNCTION。使用CALL语句调用存储过程智能用输出变量返回值。函数可以从语句外调用(通过引用函数名),也能返回标量值。存储过程也可以调用其他存储过程。php中文网还提供MySQL创建存储过程的相关下载、相关课程等内容,供大家免费下载使用。

513

2023.06.21

mongodb和mysql的区别
mongodb和mysql的区别

mongodb和mysql的区别:1、数据模型;2、查询语言;3、扩展性和性能;4、可靠性。本专题为大家提供mongodb和mysql的区别的相关的文章、下载、课程内容,供大家免费下载体验。

287

2023.07.18

mysql密码忘了怎么查看
mysql密码忘了怎么查看

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql密码忘了怎么办呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

519

2023.07.19

mysql创建数据库
mysql创建数据库

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql怎么创建数据库呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

267

2023.07.25

mysql默认事务隔离级别
mysql默认事务隔离级别

MySQL是一种广泛使用的关系型数据库管理系统,它支持事务处理。事务是一组数据库操作,它们作为一个逻辑单元被一起执行。为了保证事务的一致性和隔离性,MySQL提供了不同的事务隔离级别。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

392

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

SQL Server和MySQL是两种广泛使用的关系型数据库管理系统。它们具有相似的功能和用途,但在某些方面存在一些显著的区别。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

542

2023.08.11

mysql忘记密码
mysql忘记密码

MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。那么忘记mysql密码我们该怎么解决呢?php中文网给大家带来了相关的教程以及其他关于mysql的文章,欢迎大家前来学习阅读。

666

2023.08.14

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

22

2026.03.10

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2.5万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 846人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号