背景:把MysqL换成MysqLi时出现,连接数过多,其实际上并不是,原因是我挪动了一下PHP的sock文件位置导致,因这几个socket修改没有修改完全,于是出现了too many connections,从MysqL里show processlist并没有发现真的有连接,其实用tshark抓下包估计能看到(http://justwinit.cn/post/7458/),并没有发出请求,而估计是MysqLi的客户端自己报出来的,别看这个问题小,搞了老半天,都想重新安装PHP了,发现原来是路径写错了同时MysqLi的客户端提示连接数过多的误提示导致方向走错了。如下:
______________________排查要点如下_______________________________
warning: MysqLi::real_connect(): (hy000/1040): too many connections in:
出现场景 :
手动编译安装MysqL,并制定安装位置,PHP以localhost方式连接MysqL原因分析 :
手动编译安装制定位置后所有的MysqL文件都在制定的目录或者data目录下面,PHP默认只会寻找/temp/MysqL.sock找这个sock文件,所以会导致sock文件无法找到。解决方法 :
1.给sock文件做个软链
ln -s /data/MysqLdb/MysqL.sock /tmp/MysqL.sock;
或者
MysqL.default_socket=/data/MysqLdb/MysqL.sock
3.使用tcp socket的方式进行连接
MysqL('127.0.0.1','username','passwod');
下面给大家介绍PHP MysqL_connect() 函数
定义和用法
MysqL_connect() 函数打开非持久的 MysqL 连接。
语法
包括端口号,例如 "hostname:port",或者到本地套接字的路径,例如对于 localhost 的 ":/path/to/socket"。 PHP 指令 MysqL.default_host 未定义(默认情况),则默认值是 'localhost:3306'。 用户名。默认值是服务器进程所有者的用户名。调用 MysqL_connect(),将不会建立新连接,而将返回已经打开的连接标识。参数 new_link 改变此行为并使 MysqL_connect() 总是打开新的连接,甚至当 MysqL_connect() 曾在前面被用同样的参数调用过。 |
---|
返回值
如果成功,则返回一个 MysqL 连接标识,失败则返回 FALSE。
提示和注释
注释:脚本一结束,到服务器的连接就被关闭,除非之前已经明确调用 MysqL_close() 关闭了。 提示:要创建一个持久连接,请使用 MysqL_pconnect() 函数。
例子