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实现小型站点广告管理(修正版)
Oct 09 PHP
php adodb连接mssql解决乱码问题
Jun 12 PHP
sql注入与转义的php函数代码
Jun 17 PHP
解析PHP正则提取或替换img标记属性
Jun 26 PHP
php上传图片之时间戳命名(保存路径)
Aug 15 PHP
PHP读取txt文本文件并分页显示的方法
Mar 11 PHP
PHP 反射(Reflection)使用实例
May 12 PHP
php计算整个目录大小的方法
Jun 01 PHP
PHP7.0安装笔记整理
Aug 28 PHP
php5.2的curl-bug 服务器被php进程卡死问题排查
Sep 19 PHP
php获取文章内容第一张图片的方法示例
Jul 03 PHP
PHP swoole和redis异步任务实现方法分析
Aug 12 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
Joomla下利用configuration.php存储简单数据
2010/05/19 PHP
php单一接口的实现方法
2015/06/20 PHP
php实现生成code128条形码的方法详解
2017/07/19 PHP
javascript编程起步(第四课)
2007/02/27 Javascript
JS 拼图游戏 面向对象,注释完整。
2009/06/18 Javascript
用js实现计算加载页面所用的时间
2010/04/02 Javascript
jQuery Study Notes学习笔记 (二)
2010/08/04 Javascript
分享Javascript中最常用的55个经典小技巧
2013/11/29 Javascript
JavaScript代码编写中各种各样的坑和填坑方法
2014/06/06 Javascript
JQuery中绑定事件(bind())和移除事件(unbind())
2015/02/27 Javascript
基于JS实现的倒计时程序实例
2015/07/24 Javascript
一起学写js Calender日历控件
2016/04/14 Javascript
JavaScript中的原型prototype完全解析
2016/05/10 Javascript
JavaScript箭头函数_动力节点Java学院整理
2017/06/28 Javascript
将 vue 生成的 js 上传到七牛的实例
2017/07/28 Javascript
js 倒计时(高效率服务器时间同步)
2017/09/12 Javascript
基于JavaScript 性能优化技巧心得(分享)
2017/12/11 Javascript
layui的表单验证支持ajax判断用户名是否重复的实例
2019/09/06 Javascript
js实现视图和数据双向绑定的方法分析
2020/02/05 Javascript
javascript贪吃蛇游戏设计与实现
2020/09/17 Javascript
python实现二分查找算法
2017/09/21 Python
Python实现抢购IPhone手机
2018/02/07 Python
Django项目中使用JWT的实现代码
2019/11/04 Python
django框架auth模块用法实例详解
2019/12/10 Python
详解pycharm连接不上mysql数据库的解决办法
2020/01/10 Python
python定义类的简单用法
2020/07/24 Python
Sunglass Hut巴西网上商店:男女太阳镜
2020/10/04 全球购物
J2EE面试题大全
2016/08/06 面试题
文明学生事迹材料
2014/01/29 职场文书
科技开发中心办公室主任岗位责任制
2014/02/10 职场文书
大学开学计划书
2014/04/30 职场文书
党员民主生活会个人整改措施材料
2014/09/16 职场文书
工作失误检讨书(3篇)
2014/10/11 职场文书
从事会计工作年限证明
2015/06/23 职场文书
毕业生就业推荐表自我鉴定
2019/06/20 职场文书
html5调用摄像头实例代码
2021/06/28 HTML / CSS