查找容器IP

既然你的应用和数据库都是部署在 Docker 上的,那么之前使用的 localhostmysqld 命令就完全失效了。在 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 指的是它自己 ,而不是宿主机的数据库容器。你需要将连接地址改为数据库容器的 IPDocker 网络别名

如何获取正确的 IP?

  1. 找到数据库容器的 ID 或名称:docker ps
  2. 获取其内部 IP:docker inspect <容器ID或名称> | grep IPAddress
  3. 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 库是否已在该容器中创建。

相关推荐
唐青枫5 天前
MySQL JSON 实战详解:从存储、查询、更新到 JSON_TABLE 与索引
sql·mysql
掉头发的王富贵7 天前
【StarRocks】极限十分钟入门StarRocks
数据库·sql·mysql
zzzzzz31012 天前
9K Star 炸裂开源!这个 C 语言写的代码知识图谱,把 Linux 内核索引压缩到了 3 分钟
linux·服务器·sql
云技纵横14 天前
唯一索引 INSERT 死锁实战:5 秒复现交叉插入的 S 锁循环等待
sql·mysql
BD_Marathon16 天前
SQL学习指南——视图
数据库·sql
2601_9620725516 天前
李梦娇常识4600问|题库|打印版
sql·华为od·华为·c#·华为云·.net·harmonyos
HackTwoHub16 天前
Sqli-Scanner SQL注入SKILL自动化挖掘SQL注入,零依赖自动化SQL注入挖掘,赏金猎人
数据库·人工智能·sql·web安全·网络安全·自动化·系统安全
Volunteer Technology16 天前
Flink Table API与SQL(一)
大数据·sql·flink
持敬chijing16 天前
Web渗透之SQL注入-常用sql语句
sql·安全·web安全·网络安全
Theo·Chan16 天前
更换 Kingbase V9 License 踩坑记
sql·信创·kingbase