PHP下使用mysqli的函数连接mysql出现warning: mysqli::real_connect(): (hy000/1040): ...


Posted in PHP onFebruary 14, 2016

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

[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:

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

______________________排查要点如下_______________________________

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;

或者

2.修改php的默认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 连接。

语法

mysql_connect(server,user,pwd,newlink,clientflag)

参数 描述
server 可选。规定要连接的服务器。 可以包括端口号,例如 "hostname:port",或者到本地套接字的路径,例如对于 localhost 的 ":/path/to/socket"。 如果 PHP 指令 mysql.default_host 未定义(默认情况),则默认值是 'localhost:3306'。
user 可选。用户名。默认值是服务器进程所有者的用户名。
pwd 可选。密码。默认值是空密码。
newlink 可选。如果用同样的参数第二次调用 mysql_connect(),将不会建立新连接,而将返回已经打开的连接标识。参数 new_link 改变此行为并使 mysql_connect() 总是打开新的连接,甚至当 mysql_connect() 曾在前面被用同样的参数调用过。
clientflag 可选。client_flags 参数可以是以下常量的组合: MYSQL_CLIENT_SSL - 使用 SSL 加密 MYSQL_CLIENT_COMPRESS - 使用压缩协议 MYSQL_CLIENT_IGNORE_SPACE - 允许函数名后的间隔 MYSQL_CLIENT_INTERACTIVE - 允许关闭连接之前的交互超时非活动时间

返回值

如果成功,则返回一个 MySQL 连接标识,失败则返回 FALSE。

提示和注释

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

例子

<?php
$con = mysql_connect("localhost","mysql_user","mysql_pwd");
if (!$con)
{
die('Could not connect: ' . mysql_error());
}
// 一些代码...
mysql_close($con);
?>
PHP 相关文章推荐
用PHP将数据导入到Foxmail
Oct 09 PHP
php 无法加载mcrypt.dll的解决办法
Apr 03 PHP
php中使用getimagesize获取图片、flash等文件的尺寸信息实例
Apr 29 PHP
采用ThinkPHP中F方法实现快速缓存实例
Jun 13 PHP
PHP两种去掉数组重复值的方法比较
Jun 19 PHP
PHP中使用匿名函数操作数据库的例子
Nov 17 PHP
php防止网站被刷新的方法汇总
Dec 01 PHP
PHP中file_exists使用中遇到的问题小结
Apr 05 PHP
php中this关键字用法分析
Dec 07 PHP
php使用Jpgraph创建3D饼形图效果示例
Feb 15 PHP
PHP数组常用函数实例小结
Aug 20 PHP
php简单检测404页面的方法示例
Aug 23 PHP
PHP缓冲区用法总结
Feb 14 #PHP
PHP二维数组排序简单实现方法
Feb 14 #PHP
php的闭包(Closure)匿名函数初探
Feb 14 #PHP
PHP5.3新特性小结
Feb 14 #PHP
PHP解压tar.gz格式文件的方法
Feb 14 #PHP
最新版本PHP 7 vs HHVM 多角度比较
Feb 14 #PHP
PHP使用socket发送HTTP请求的方法
Feb 14 #PHP
You might like
PHP将两个关联数组合并函数提高函数效率
2014/03/18 PHP
PHP @ at 记号的作用示例介绍
2014/10/10 PHP
php PDO异常处理详解
2016/11/20 PHP
网页的标准,IMG不支持onload标签怎么办
2006/06/29 Javascript
jquery 循环显示div的示例代码
2013/10/18 Javascript
javascript打印html内容功能的方法示例
2013/11/28 Javascript
深入分析jquery解析json数据
2014/12/09 Javascript
Jquery代码实现图片轮播效果(一)
2015/08/12 Javascript
jQuery实现两款有动画功能的导航菜单代码
2015/09/16 Javascript
JS读写CSS样式的方法汇总
2016/08/16 Javascript
Node.js调试技术总结分享
2017/03/12 Javascript
jQuery插件HighCharts实现的2D面积图效果示例【附demo源码下载】
2017/03/15 Javascript
ES6中新增的Object.assign()方法详解
2017/09/22 Javascript
用Electron写个带界面的nodejs爬虫的实现方法
2019/01/29 NodeJs
vue3.0中友好使用antdv示例详解
2021/01/05 Vue.js
[43:49]LGD vs CHAOS 2019国际邀请赛小组赛 BO2 第一场 8.15
2019/08/16 DOTA
[01:33:25]DOTA2-DPC中国联赛 正赛 Elephant vs IG BO3 第一场 1月24日
2021/03/11 DOTA
python中pycurl库的用法实例
2014/09/30 Python
Python实现端口检测的方法
2018/07/24 Python
python3 打开外部程序及关闭的示例
2018/11/06 Python
python 在指定范围内随机生成不重复的n个数实例
2019/01/28 Python
python 实现在tkinter中动态显示label图片的方法
2019/06/13 Python
django实现支付宝支付实例讲解
2019/10/17 Python
使用python的turtle函数绘制一个滑稽表情
2020/02/28 Python
Numpy中np.max的用法及np.maximum区别
2020/11/27 Python
pyqt5实现井字棋的示例代码
2020/12/07 Python
python爬取代理ip的示例
2020/12/18 Python
浅析python连接数据库的重要事项
2021/02/22 Python
html5 的a标签 Href 拨电话的写法
2013/11/04 HTML / CSS
瑞典廉价机票预订网站:Seat24
2018/06/19 全球购物
写好求职信第一句话的技巧
2013/10/26 职场文书
分公司经理岗位职责
2013/11/11 职场文书
节约用水标语
2014/06/11 职场文书
党员学习新党章思想汇报
2014/10/25 职场文书
《观潮》教学反思
2016/02/17 职场文书
什么是创业计划书?什么是商业计划书?这里一一解答
2019/07/12 职场文书