mysql_connect报告”No such file or directory”错误的解决方法
这篇讲的是在Mac MacBook Pro上安装WordPress时遇到的一个经典坑:PHP脚本调用`mysql_connect()`连接本地数据库时,竟然报出“No such file or directory”的错误。作者首先排除了数据库服务器本身的问题,因为MySQL命令行客户端可以正常工作,这让人很困惑——连接数据库怎么还和“文件”扯上关系了? 问题的根源其实非常隐蔽且具有平台特异性。在macOS和某些Linux环境下,PHP的`mysqli`扩展默认尝试通过Unix socket连接MySQL,而非TCP/IP。这个socket文件的具体路径(比如`/tmp/mysql.sock`或`/var/mysql/mysql.sock`)在不同系统或安装方式下可能不一致,如果PHP配置的路径与MySQL服务器实际创建socket的路径不匹配,就会报这个看似不相关的文件系统错误。 文章的解决步骤清晰且具有实操性:通过phpinfo()查看当前PHP的socket路径配置,再定位MySQL服务器实际的socket文件位置,最后在`php.ini`或代码中通过`mysqli.default_socket`参数将其统一。这个案例典型地展示了环境配置中“默认值不一致”带来的陷阱,对于在本地搭建开发环境的PHP开发者尤其有参考价值,能避免在排查连接问题时走入死胡同。