首先需要明确PHP错误日志的存储位置,不同Web服务器(Apache/Nginx)或PHP运行模式(PHP-FPM)的路径可能不同:
/var/log/php-fpm/error.log;/var/log/httpd/error_log;/var/log/nginx/error.log(需结合Nginx配置中的error_log指令确认)。cat /etc/php.ini | grep error_log或cat /etc/php-fpm.conf | grep error_log命令进一步验证日志路径。使用tail命令实时监控日志文件的最新条目,快速定位数据库连接相关的错误信息(如连接超时、认证失败等):
sudo tail -f /var/log/php-fpm/error.log # 若使用PHP-FPM
# 或
sudo tail -f /var/log/httpd/error_log # 若使用Apache
重点关注错误信息中的关键词(如“mysqli_connect_error”、“PDOException”、“Access denied for user”),这些关键词能快速指向连接问题的类型。
根据日志中的错误信息,针对性解决以下常见问题:
yum安装对应扩展(如sudo yum install php-mysqlnd),安装后重启PHP-FPM(sudo systemctl restart php-fpm)或Apache(sudo systemctl restart httpd)使扩展生效。config.php中的host、username、password、dbname),确保与数据库实际的用户名、密码、数据库名一致。systemctl status mysqld检查服务状态,未运行则启动服务(sudo systemctl start mysqld),并设置开机自启(sudo systemctl enable mysqld)。ping <数据库服务器IP>)、防火墙设置(如firewall-cmd --list-ports是否开放数据库端口,默认MySQL为3306),确保PHP服务器能访问数据库服务器的对应端口。若上述步骤无法解决复杂问题,可使用调试工具追踪代码执行流程和变量值:
php.ini,添加zend_extension=xdebug.so及相关调试参数),通过IDE(如PHPStorm)设置断点,逐步执行代码,查看数据库连接时的变量值(如$host、$username)和执行流程,定位具体出错位置。若日志信息不够详细,可修改php.ini文件提高错误报告级别,确保数据库连接错误被完整记录:
error_reporting = E_ALL & ~E_NOTICE # 报告所有错误(除Notice外)
display_errors = Off # 关闭页面显示错误(避免敏感信息泄露)
log_errors = On # 开启日志记录错误
error_log = /var/log/php-fpm/error.log # 指定错误日志路径
修改后重启PHP-FPM或Apache服务,使配置生效。
修复问题后,重新加载Web应用(如刷新页面),并继续监控日志文件(sudo tail -f /var/log/php-fpm/error.log),确认是否还有数据库连接相关的错误信息。若无新错误,则问题已解决;若仍有错误,需重复上述步骤进一步排查。