您的位置:首页 > 编程语言 > PHP开发

解决编译安装的PHP无法通过localhost连接mysql的问题

2017-04-10 09:55 1076 查看
首先搞清楚mysql之连接localhost与127.0.0.1的区别:

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

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



但无法通过localhost连接mysql:




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



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

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

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








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

查看mysql套接字路径:
# cat /etc/my.cnf




创建软连接:
# ln -s /var/lib/mysql/mysql.sock /tmp




问题解决:


内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  mysql 127.0.0.1 localhsot