查找容器IP
既然你的应用和数据库都是部署在 Docker 上的,那么之前使用的localhost或mysqld命令就完全失效了。在 Docker 环境中,网络架构和宿主机是隔离的,这也是导致你连接超时(Connection is not available, request timed out after 30000ms)的根本原因。
以下是针对 Docker 环境的精准排查和解决步骤:
1. 检查数据库容器是否正常运行
首先,你需要确认数据库的 Docker 容器是否真的在运行。在服务器上执行:
docker ps -a | grep mysql- 如果状态(STATUS)是
Up,说明容器在运行。 - 如果状态是
Exited或不断重启(Restarting),说明数据库挂了。请使用docker logs <容器ID>查看报错日志。
2. 修改数据库连接 IP(最关键的一步)
在 Docker 中,你的 Java 应用容器内的localhost指的是它自己,而不是宿主机的数据库容器。你需要将连接地址改为数据库容器的 IP或Docker 网络别名。
如何获取正确的 IP?
- 找到数据库容器的 ID 或名称:
docker ps - 获取其内部 IP:
docker inspect <容器ID或名称> | grep IPAddress - 将
application.properties中的 URL 修改为:jdbc:mysql://<获取到的IP>:3306/newbee_mall_db?...
(注:如果你使用了 Docker Compose 编排,可以直接使用数据库的服务名,例如jdbc:mysql://db:3306/...)
3. 排查容器内的资源竞争与启动顺序
在 Docker 环境中,容器之间的资源竞争可能导致性能问题。如果你的应用启动速度比数据库快,应用会在数据库完全初始化前尝试连接,从而导致连接超时。
解决方案:
- 依赖管理:确保应用启动依赖于数据库容器完全运行。如果使用 Docker Compose,请配置
depends_on及健康检查(healthcheck)。 - 重试机制:在应用中实现重试机制,或在 HikariCP 中配置初始化允许失败并慢慢重试:
# 初始化时允许失败,慢慢重试 spring.datasource.hikari.initialization-fail-timeout=-1 spring.datasource.hikari.connection-timeout=30000
4. 检查 Docker 资源限制
如果数据库服务器或应用程序容器资源不足(CPU、内存),可能会出现连接超时。
- 使用
docker stats命令监控容器内的 CPU 和内存使用情况,识别是否存在资源瓶颈。 - 确保为数据库容器分配了足够的内存(MySQL 建议至少 512M 以上)。
💡 快速验证建议:
你可以直接进入你的 Java 应用容器内部,尝试连接数据库,以隔离网络问题:
# 进入应用容器 docker exec -it <你的java应用容器ID> /bin/bash # 在容器内尝试 ping 数据库 IP 或 telnet 3306 端口 ping <数据库容器IP>如果 ping 不通或连不上,说明是 Docker 网络配置问题;如果能通,请仔细检查数据库的账号密码及newbee_mall_db库是否已在该容器中创建。
