检查数据库服务状态
确保数据库服务已启动,如MySQL可通过命令:
sudo systemctl status mysql
未启动则执行:sudo systemctl start mysql
。
验证连接参数
确认Java代码中的连接字符串、用户名、密码正确,例如MySQL连接字符串:
String url = "jdbc:mysql://localhost:3306/mydb?useSSL=false&serverTimezone=UTC"
。
添加JDBC驱动
pom.xml
中添加依赖(以MySQL 8.0为例):<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.28</version>
</dependency>
检查数据库权限
确保数据库用户有访问权限,可通过SQL命令授权:
GRANT ALL PRIVILEGES ON mydb.* TO 'myuser'@'localhost'; FLUSH PRIVILEGES;
。
排查防火墙与网络
检查防火墙是否限制端口(如MySQL默认3306):
sudo ufw status
,必要时放行端口:sudo ufw allow 3306/tcp
。
使用连接池优化
引入连接池(如HikariCP)管理连接,避免频繁创建/关闭连接,提升性能。
查看日志与调试
检查数据库日志(如MySQL的/var/log/mysql/error.log
)和Java程序日志,获取具体错误信息;可通过JDBC参数启用调试模式,如loggerName=org.hibernate.SQL
。
参考来源: