温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

PHP无法通过localhost成功连接mysql怎么办

发布时间:2020-06-08 11:03:12 来源:网络 阅读:598 作者:三月 栏目:MySQL数据库

下面一起来了解下PHP无法通过localhost成功连接mysql怎么办,相信大家看完肯定会受益匪浅,文字在精不在多,希望PHP无法通过localhost成功连接mysql怎么办这篇短内容是你想要的。

首先搞清楚mysql之连接localhost与127.0.0.1的区别:

127.0.0.1属于TCP/IP连接,是通过网卡传输,依赖网卡,并受到网络防火墙和网卡相关的限制。localhot属于Unix socket方式连接,是不经网卡传输!它不会解析成 IP,不受网络防火墙和网卡相关的的限制,也不会占用网卡、网络资源。一般设置程序时本地服务用localhost是最好的。



我的操作系统php使用127.0.0.1却能连接mysql:

PHP无法通过localhost成功连接mysql怎么办



但无法通过localhost连接mysql:

PHP无法通过localhost成功连接mysql怎么办


尝试phpmyadmin也遇到同样的错误,不过也出现比较有价值的错误提示(套接字没有正确设置):

PHP无法通过localhost成功连接mysql怎么办

这里说套接字指的是php跟mysql通信的一个.sock文件。


分析一下问题:

我的mysql使用的是mariadb5.5,通过yum安装,所以问题出在mysql本身的可能性几乎没有。


通过phpinfo查找socket关键字,可以发现mysql.default_socket没有设置默认值,而pdo_mysql给出了默认值,sock的位置


PHP无法通过localhost成功连接mysql怎么办

PHP无法通过localhost成功连接mysql怎么办


编辑php.ini给予mysql.default_socket默认路径,并且跟mysql的套接字文件存放路径对应按理就能解决问题。不过还有个偷懒的办法,把mysql的套接字文件在php指定的默认路径创建软连接,就无需修改php.ini了。


查看mysql套接字路径:

# cat /etc/my.cnf

PHP无法通过localhost成功连接mysql怎么办


创建软连接:

# ln -s /var/lib/mysql/mysql.sock /tmp 

PHP无法通过localhost成功连接mysql怎么办


问题解决:

PHP无法通过localhost成功连接mysql怎么办

看完PHP无法通过localhost成功连接mysql怎么办这篇文章后,很多读者朋友肯定会想要了解更多的相关内容,如需获取更多的行业信息,可以关注我们的行业资讯栏目。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI