php7的配置文件里没有mysql.default_socket吗?

php中文网
发布: 2016-12-05 13:44:23
原创
2407人浏览过

[更新]刚刚查文档注意到,php7已经不支持mysql扩展了,但是我应该怎么解决只能用127.0.0.1链接,不能使用localhost链接的问题呢?

…………………………………………………………………………………………

为什么会有这个问题呢?
我写了一个PHP脚本来链接数据库,代码如下,当如果mysql的地址是127.0.0.1,则能够能够链接,如果地址换成localhost,则提示`PHP Warning: mysqli::mysqli(): (HY000/2002): No such file or directory in /home/wwwroot/default/cenyu/Goitems/Goitems/connect_mysql.php on line 9
`

<code>$mysqli = new mysqli("127.0.0.1", "root", "root", "wordpress");
if (mysqli_connect_errno()) {
    echo 'Error: Could not connect to database. Please try again later.';
    echo "\n";
    exit;
}else{
    echo "Connect! \n";
}


$sql = "SELECT * FROM wp_amz_key;";
$result = $mysqli->query($sql);

/* close connection */
$mysqli->close();
</code>
登录后复制

然后我搜索了一些解决方法,主要是修改php.ini的配置文件里这三个选项的值

标贝悦读AI配音
标贝悦读AI配音

在线文字转语音软件-专业的配音网站

标贝悦读AI配音 20
查看详情 标贝悦读AI配音
<code>pdo_mysql.default_socket=/tmp/mysql.sock
mysql.default_socket=/tmp/mysql.sock
mysqli.default_socket = /tmp/mysql.sock</code>
登录后复制

然后我的问题就出现了:
我的ubuntu上使用的是php7,通过phpinfo查到php.ini的文件,打开之后,没有mysql.default_socket
参数,只有其他两个,然后我又查看版本的php.ini发现是有mysql.default_socket,所以请问PHP7的配置文件里没有mysql.default_socket吗?
所以,我的问题是:
1.脚本中链接数据库出现问题,是不是可以通过这种方法解决?
2.PHP7中的php.ini配置文件是不是没有mysql.default_socket,还是我安装的有问题?
先谢谢大神

立即学习PHP免费学习笔记(深入)”;

回复内容:

[更新]刚刚查文档注意到,php7已经不支持mysql扩展了,但是我应该怎么解决只能用127.0.0.1链接,不能使用localhost链接的问题呢?

…………………………………………………………………………………………

为什么会有这个问题呢?
我写了一个PHP脚本来链接数据库,代码如下,当如果mysql的地址是127.0.0.1,则能够能够链接,如果地址换成localhost,则提示`PHP Warning: mysqli::mysqli(): (HY000/2002): No such file or directory in /home/wwwroot/default/cenyu/Goitems/Goitems/connect_mysql.php on line 9
`

<code>$mysqli = new mysqli("127.0.0.1", "root", "root", "wordpress");
if (mysqli_connect_errno()) {
    echo 'Error: Could not connect to database. Please try again later.';
    echo "\n";
    exit;
}else{
    echo "Connect! \n";
}


$sql = "SELECT * FROM wp_amz_key;";
$result = $mysqli->query($sql);

/* close connection */
$mysqli->close();
</code>
登录后复制

然后我搜索了一些解决方法,主要是修改php.ini的配置文件里这三个选项的值

<code>pdo_mysql.default_socket=/tmp/mysql.sock
mysql.default_socket=/tmp/mysql.sock
mysqli.default_socket = /tmp/mysql.sock</code>
登录后复制

然后我的问题就出现了:
我的ubuntu上使用的是php7,通过phpinfo查到php.ini的文件,打开之后,没有mysql.default_socket
参数,只有其他两个,然后我又查看版本的php.ini发现是有mysql.default_socket,所以请问PHP7的配置文件里没有mysql.default_socket吗?
所以,我的问题是:
1.脚本中链接数据库出现问题,是不是可以通过这种方法解决?
2.PHP7中的php.ini配置文件是不是没有mysql.default_socket,还是我安装的有问题?
先谢谢大神

立即学习PHP免费学习笔记(深入)”;

没有 mysql.default_socket
但是有 mysqli.default_socketpdo_mysql.default_socket
因为有mysqli所以PHP7不再支持老旧的mysql扩展.

不过我们通常是通过IP和端口连接MySQL,这种情况下并不需要指定什么default_socket.
直接 $db = new mysqli('127.0.0.1','root','pass','mysql',3306);不就行了.
就算你要通过socket连接MySQL,同样也可以在连接时指定:
$db = new mysqli(null,'root','pass','mysql',null,'/path/to/mysqld.sock');
所以并不需要纠结任何事情.

都在本地的话,用socket和用ip地址并没有什么区别。

1、检查mysql配置文件my.conf中是否有一行bind-address = 127.0.0.1,如果有的话加#注释或者删掉重启mysql

2、查看mysql的账号允许链接的主机是否限制为127.0.0.1了
SELECT User, Host FROM mysql.user;

相关标签:
php
PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号