加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

PHP编程:PHP下使用mysqli的函数连接mysql出现warning: mysqli::

发布时间:2020-12-13 03:07:55 所属栏目:PHP教程 来源:网络整理
导读:《PHP下使用mysqli的函数连接mysql出现warning: mysqli::real》要点: 本文介绍了PHP下使用mysqli的函数连接mysql出现warning: mysqli::real,希望对您有用。如果有疑问,可以联系我们。 背景:把mysql换成mysqli时出现,连接数过多,其实际上并不是,原因是我

《PHP下使用mysqli的函数连接mysql出现warning: mysqli::real》要点:
本文介绍了PHP下使用mysqli的函数连接mysql出现warning: mysqli::real,希望对您有用。如果有疑问,可以联系我们。

背景:把mysql换成mysqli时出现,连接数过多,其实际上并不是,原因是我挪动了一下php的sock文件位置导致,因这几个socket修改没有修改完全,于是出现了too many connections,从mysql里show processlist并没有发现真的有连接,其实用tshark抓下包估计能看到(http://justwinit.cn/post/7458/),并没有发出哀求,而估计是mysqli的客户端自己报出来的,别看这个问题小,搞了老半天,都想重新安装Php了,发现原来是路径写错了同时mysqli的客户端提示连接数过多的误提示导致方向走错了.如下:PHP实战

[root@iZ25z0ugwgtZ etc]# grep -r "mysql.sock" ./
./php.ini:pdo_mysql.default_socket=/data/runsock/mysqlsock/mysql.sock
./php.ini:;mysql.default_socket = /tmp/mysql.sock
./php.ini:mysql.default_socket = /data/runsock/mysqlsock/mysql.sock
./php.ini:mysqli.default_socket = /data/runsock/mysql.sock //这个位置被挪动到,/data/runsock/mysqlsock/mysql.sock导致.

修改跋文得重启动php-fpm:PHP实战

[root@iZ25z0ugwgtZ etc]# service php-fpm restart
Gracefully shutting down php-fpm . done
Starting php-fpm done

______________________排查要点如下_______________________________PHP实战

warning: mysqli::real_connect(): (hy000/1040): too many connections in:PHP实战

呈现场景 :手动编译安装mysql,并制定安装位置,php以localhost方式连接mysqlPHP实战

原因阐发 :手动编译安装制定位置后所有的mysql文件都在制定的目录或者data目录下面,php默认只会寻找/temp/mysql.sock找这个sock文件,所以会导致sock文件无法找到.PHP实战

解决办法 :PHP实战

1.给sock文件做个软链PHP实战

ln -s /data/mysqldb/mysql.sock /tmp/mysql.sock;PHP实战

又或PHP实战

2.改动php的默认mysql.sock连接地址PHP实战

mysql.default_socket=/data/mysqldb/mysql.sockPHP实战

3.使用tcp socket的方式进行衔接PHP实战

mysql('127.0.0.1','username','passwod');PHP实战

下面给年夜家介绍PHP mysql_connect() 函数PHP实战

界说和用法PHP实战

mysql_connect() 函数打开非持久的 MySQL 衔接.PHP实战

语法PHP实战

mysql_connect(server,user,pwd,newlink,clientflag)
参数 描述
server

可选.划定要连接的服务器.PHP实战

可以包含端口号,例如 "hostname:port",或者到本地套接字的路径,例如对于 localhost 的 ":/path/to/socket".PHP实战

如果 PHP 指令 mysql.default_host 未界说(默认情况),则默认值是 'localhost:3306'.PHP实战

user 可选.用户名.默认值是服务器进程所有者的用户名.
pwd 可选.暗码.默认值是空暗码.
newlink 可选.如果用同样的参数第二次调用 mysql_connect(),将不会建立新连接,而将返回已经打开的连接标识.参数 new_link 改变此行为并使 mysql_connect() 总是打开新的连接,甚至当 mysql_connect() 曾在前面被用同样的参数调用过.
clientflag

可选.client_flags 参数可以是以下常量的组合:PHP实战

  • MYSQL_CLIENT_SSL - 使用 SSL 加密
  • MYSQL_CLIENT_COMPRESS - 使用压缩协议
  • MYSQL_CLIENT_IGNORE_SPACE - 允许函数名后的间隔
  • MYSQL_CLIENT_INTERACTIVE - 允许封闭连接之前的交互超时非活动时间

返回值PHP实战

如果胜利,则返回一个 MySQL 连接标识,失败则返回 FALSE.PHP实战

提醒和注释PHP实战

注释:脚本一结束,到服务器的连接就被关闭,除非之前已经明确调用 mysql_close() 关闭了.
提示:要创立一个持久连接,请使用 mysql_pconnect() 函数.PHP实战

例子PHP实战

<必修php
$con = mysql_connect("localhost","mysql_user","mysql_pwd");
if (!$con)
{
die('Could not connect: ' . mysql_error());
}
// 一些代码...
mysql_close($con);
必修>

欢迎参与《PHP下使用mysqli的函数连接mysql出现warning: mysqli::real》讨论,分享您的想法,编程之家 52php.cn为您提供专业教程。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读