
本文档旨在帮助开发者解决Docker容器中运行的Java 11应用无法连接到MySQL 8数据库的问题。通过分析常见的配置错误,例如端口映射和数据库连接URL配置,提供详细的排查步骤和解决方案,确保应用能够成功连接到数据库。
在Docker容器中部署Java应用并连接MySQL数据库时,可能会遇到连接被拒绝的问题。这通常是由于以下几个原因造成的:
以下步骤将帮助您诊断和解决Docker容器中Java应用连接MySQL数据库的问题:
检查Docker Compose文件(docker-compose.yml)
立即学习“Java免费学习笔记(深入)”;
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检查Java应用的配置文件(application.yml)
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验证MySQL配置
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'pass'; FLUSH PRIVILEGES;
注意: 在生产环境中,不建议允许来自任何主机的连接。 应限制为仅允许来自应用容器的连接。
检查Dockerfile
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());
}
}
}通过仔细检查Docker Compose文件、Java应用的配置文件和MySQL配置,可以解决Docker容器中Java应用连接MySQL数据库的问题。确保端口映射、数据库连接URL和网络配置正确,是成功连接的关键。
以上就是Docker容器中Java 11应用连接MySQL 8数据库失败问题排查与解决的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号