0

0

Docker容器中Java 11应用连接MySQL 8数据库失败问题排查与解决

聖光之護

聖光之護

发布时间:2025-09-17 21:44:00

|

771人浏览过

|

来源于php中文网

原创

docker容器中java 11应用连接mysql 8数据库失败问题排查与解决

本文档旨在帮助开发者解决Docker容器中运行的Java 11应用无法连接到MySQL 8数据库的问题。通过分析常见的配置错误,例如端口映射和数据库连接URL配置,提供详细的排查步骤和解决方案,确保应用能够成功连接到数据库。

问题分析

在Docker容器中部署Java应用并连接MySQL数据库时,可能会遇到连接被拒绝的问题。这通常是由于以下几个原因造成的:

  1. 端口映射错误: Docker Compose文件中定义的端口映射只影响宿主机与容器之间的通信,容器内部服务之间的通信应使用容器内部端口。
  2. 数据库连接URL配置错误: Java应用中的数据库连接URL必须指向MySQL容器的内部服务名和端口。
  3. 网络配置问题: 确保应用和数据库容器在同一个Docker网络中,以便它们可以相互发现。
  4. MySQL配置问题: MySQL服务器可能未配置为允许来自其他容器的连接。

解决方案

以下步骤将帮助您诊断和解决Docker容器中Java应用连接MySQL数据库的问题:

  1. 检查Docker Compose文件(docker-compose.yml)

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

    • 确保Java应用(server)和MySQL数据库(mysqldb)容器都位于同一个网络(app-network)中。
    • 验证MySQL容器的端口映射是否正确。ports 部分定义了宿主机端口到容器端口的映射,但容器内部服务之间的通信应使用容器内部端口。
    version: '3.8'
    
    services:
      server:
        container_name: movies-app
        build: .
        restart: always
        ports:
          - "8088:8080"
        networks:
          - app-network
    
      mysqldb:
        container_name: mysqldb
        image: mysql:8.0.28
        restart: always
        ports:
          - "3307:3306"
        environment:
          MYSQL_DATABASE: moviesdb
          MYSQL_USER: user
          MYSQL_PASSWORD: pass
          MYSQL_ROOT_USER: root
          MYSQL_ROOT_PASSWORD: pass
        volumes:
          - dbdata:/var/lib/mysql
        networks:
          - app-network
    
    networks:
      app-network:
        driver: bridge
    
    volumes:
      dbdata:
        driver: local
  2. 检查Java应用的配置文件(application.yml)

    Devin
    Devin

    世界上第一位AI软件工程师,可以独立完成各种开发任务。

    下载
    • 确保数据库连接URL指向MySQL容器的服务名(mysqldb)和容器内部端口(3306)。 不要使用映射到宿主机的端口(3307)。
    spring:
      datasource:
        password: pass
        driver-class-name: com.mysql.cj.jdbc.Driver
        username: root
        url: jdbc:mysql://mysqldb:3306/moviesdb?createDatabaseIfNotExist=true&allowPublicKeyRetrieval=true&useSSL=false
  3. 验证MySQL配置

    • 确保MySQL服务器允许来自其他容器的连接。 在MySQL容器中,您可能需要执行以下命令来允许来自任何主机的连接:
    GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'pass';
    FLUSH PRIVILEGES;

    注意: 在生产环境中,不建议允许来自任何主机的连接。 应限制为仅允许来自应用容器的连接。

  4. 检查Dockerfile

    • 确保Dockerfile中安装了正确的JDK版本。虽然问题描述中提到了Java版本,但Dockerfile中存在多个FROM指令,这可能导致最终使用的JDK版本不正确。建议只保留一个FROM指令,并确保该指令指向正确的JDK版本。
    • 移除不必要的mvn clean install 命令。该命令通常用于构建项目,但在Docker环境中,通常在构建镜像之前完成。
    FROM maven:3.8.1-openjdk-11
    
    COPY target/*.jar app.jar
    
    EXPOSE 8088
    ENTRYPOINT ["java", "-jar", "-Dspring.profiles.active=docker", "app.jar"]

示例代码

以下是一个简化的Java应用示例,用于测试与MySQL数据库的连接:

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;

public class DatabaseConnector {

    public static void main(String[] args) {
        String url = "jdbc:mysql://mysqldb:3306/moviesdb?createDatabaseIfNotExist=true&allowPublicKeyRetrieval=true&useSSL=false";
        String user = "root";
        String password = "pass";

        try (Connection connection = DriverManager.getConnection(url, user, password)) {
            System.out.println("Successfully connected to the database!");
        } catch (SQLException e) {
            System.err.println("Failed to connect to the database: " + e.getMessage());
        }
    }
}

注意事项

  • 在生产环境中,应使用更安全的密码管理方法,例如使用环境变量或密钥管理服务。
  • 定期更新MySQL镜像以获取最新的安全补丁。
  • 监控容器的资源使用情况,并根据需要调整资源限制。

总结

通过仔细检查Docker Compose文件、Java应用的配置文件和MySQL配置,可以解决Docker容器中Java应用连接MySQL数据库的问题。确保端口映射、数据库连接URL和网络配置正确,是成功连接的关键。

热门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的相关下载、相关课程等内容,供大家免费下载使用。

668

2023.06.20

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

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

247

2023.06.21

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

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

281

2023.07.18

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

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

515

2023.07.19

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

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

256

2023.07.25

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

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

386

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

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

533

2023.08.11

mysql忘记密码
mysql忘记密码

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

602

2023.08.14

俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

158

2026.01.28

热门下载

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

精品课程

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

共48课时 | 2万人学习

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

共3课时 | 0.3万人学习

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

共1课时 | 812人学习

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

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