php使用pdo连接报错Connection failed SQLSTATE的解决方法,pdosqlstate
php使用pdo连接报错Connection failed SQLSTATE的解决方法,pdosqlstate
本文实例讲述了php pdo_mysql连接报错Connection failed: SQLSTATE[HY000] [2002] No such file or directory问题的解决方法。分享给大家供大家参考。具体方法如下:
错误描述:
Connection failed: SQLSTATE[HY000] [2002] No such file or directory
环境概述:
MacOS
xampp 搭建的开发环境 apache mysql php
xampp 已支持mysql oracle 测试ok,且 phpinfo已上显示支持pdo_mysql pdo_pgsql pdo_sqlite
其中mysql我用的是brew包管理安装到机器里面的,而非xampp自带的mysql
php pdo 连接报错 Connection failed: SQLSTATE[HY000] [2002] No such file or directory
开始以为找不到文件是因为 url rewrite导致的,(因为从nginx切换到apache)结果跟踪程序发现是 new pdo 报错
经过搜索一些资料研究发现:
这个是php.ini配置文件中pdo_mysql.default_socket指定的mysql.sock路径不对
我的mysql.sock文件在 /private/tmp/mysql.sock
所以要设置:
复制代码 代码如下:
pdo_mysql.default_socket=/private/tmp/mysql.sock
如果不知道自己的mysql.sock在哪里可以搜索(因为编译安装,和yum、apt-get、或者brew等包管理工具安装的位置不一样)
sudo find / -name 'mysql.sock'
下面是官方给出bug修复
1. Open up php.ini (mine was in /private/etc/)
2. locate this line: pdo_mysql.default_socket=/var/mysql/mysql.sock
3. Change the line to: pdo_mysql.default_socket=/tmp/mysql.sock
4. Restart apache
1、我这里需要补充下,如果是新系统或者刚玩php的同志,在Mac的系统中php.ini 文件不存在。
2、需要在/private/etc/目录下cp php.ini.default
php.ini ,然后再做修改下
3、但是如果使用的xampp mysql作为数据库,那么就不需要使用官方的step2,直接写下面方式就可以了。
复制代码 代码如下:
pdo_mysql.default_socket=/Applications/XAMPP/xamppfiles/var/mysql/mysql.sock
解决方法三:
复制代码 代码如下:
sudo vim /etc/php.ini
把以下三个原来空白的值都设置为:
复制代码 代码如下:
/tmp/mysql.sock
mysql.default_socket = /tmp/mysql.sock
pdo_mysql.default_socket= /tmp/mysql.sock
mysqli.default_socket =/tmp/mysql.sock
都修改了
修改完成后使用
复制代码 代码如下:
sudo /usr/sbin/apachectl restart
问题搞定!
希望本文所述对大家的PHP程序设计有所帮助。

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

DeepSeek:火爆AI遭遇服务器拥堵,如何应对?DeepSeek作为2025年开年爆款AI,免费开源且性能媲美OpenAIo1正式版,其受欢迎程度可见一斑。然而,高并发也带来了服务器繁忙的问题。本文将分析原因并提供应对策略。DeepSeek网页版入口:https://www.deepseek.com/DeepSeek服务器繁忙的原因:高并发访问:DeepSeek的免费和强大功能吸引了大量用户同时使用,导致服务器负载过高。网络攻击:据悉,DeepSeek对美国金融界造成冲击,

Gate.io交易所为用户提供官方登录入口。通过官方网站或移动应用程序,用户可以登录其账户。登录步骤简便,包括输入注册时使用的电子邮件或手机号码,以及密码。为了确保账户安全,建议用户定期更改密码并妥善保管登录信息。此外,文中还提供了针对常见登录问题的解决方法,包括无法登录和密码丢失等情况。

芝麻开门交易所怎么调成中文?本教程涵盖电脑、安卓手机端详细步骤,从前期准备到操作流程,再到常见问题解决,帮你轻松将芝麻开门交易所界面切换为中文,快速上手交易平台。

芝麻开门交易所 app 官方下载步骤,涵盖安卓、iOS 系统下载流程,以及常见问题解决方法,助你安全、快速下载,开启加密货币便捷交易。

详细介绍芝麻开门交易所网页版登入口操作,含登录步骤、找回密码流程,还针对登录失败、无法打开页面、收不到验证码等常见问题提供解决方法,助你顺利登录平台。

在数字货币交易平台进行交易时,最令人担忧的情况莫过于买币后卖家未放币或买家无法付款。这两种情况都会严重影响后续交易。本文将重点讲解买家无法付款的应对方法。买币无法付款怎么办?遇到无法付款的情况,首先应检查自身支付方式及账户状态,其次确认网络及交易平台是否正常运行。若问题依旧,联系平台客服通常是最有效的解决途径。以下是一些更详细的解决方法:支付方式问题:部分银行或信用卡机构可能限制加密货币相关交易,尤其涉及国际支付。建议尝试联系银行或信用卡公司了解限制情况并寻求临时解除;或改用其他支付方式,

彻底了解币安账户删除流程及注意事项!本文将详细指导您如何删除币安账户,并提供在删除前需要检查的关键事项。删除币安账户的原因分析用户可能出于以下原因选择删除币安账户:未填写推荐码:许多用户在注册时未填写推荐码,错失手续费优惠。由于币安不支持事后补填,删除账户并重新注册是唯一解决方法。更换交易所:用户可能因界面、功能或验证流程等原因选择更换交易所,并决定删除币安账户。安全顾虑:交易所安全事件可能导致用户担忧,选择删除账户以降低风险。删除币安账户流程请务必在删除账户前确
