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基础之运算符的使用方法
Apr 28 PHP
PHP APC的安装与使用详解
Jun 13 PHP
php 模拟GMAIL,HOTMAIL(MSN),YAHOO,163,126邮箱登录的详细介绍
Jun 18 PHP
如何取得中文字符串中出现次数最多的子串
Aug 08 PHP
PHP OPP机制和模式简介(抽象类、接口和契约式编程)
Jun 09 PHP
PHP打开和关闭文件操作函数总结
Nov 18 PHP
php实现无限级分类
Dec 24 PHP
PHP5.3连接Oracle客户端及PDO_OCI模块的安装方法
May 13 PHP
PHP实现登录验证码校验功能
May 17 PHP
python进程与线程小结实例分析
Nov 11 PHP
PHP的mysqli_sqlstate()函数讲解
Jan 23 PHP
php上传后台无法收到数据解决方法
Oct 28 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
国内咖啡文化
2021/03/03 咖啡文化
php4的session功能评述(三)
2006/10/09 PHP
linux实现php定时执行cron任务详解
2013/12/24 PHP
PHP中捕获超时事件的方法实例
2015/02/12 PHP
php判断数组是否为空的实例方法
2020/05/10 PHP
IE6/7/8/9不支持exec的简写方式
2011/05/25 Javascript
使用jquery hover事件实现表格的隔行换色功能示例
2013/09/03 Javascript
javascript间隔定时器(延时定时器)学习 间隔调用和延时调用
2014/01/13 Javascript
jquery访问ashx文件示例代码
2014/08/11 Javascript
JavaScript实现级联菜单的方法
2015/06/29 Javascript
JavaScript调用客户端Java程序的方法
2015/07/27 Javascript
分享自己用JS做的扫雷小游戏
2016/02/17 Javascript
vue通过路由实现页面刷新的方法
2018/01/25 Javascript
用Axios Element实现全局的请求loading的方法
2018/03/15 Javascript
基于vue的验证码组件的示例代码
2019/01/22 Javascript
js实现鼠标拖拽缩放div实例代码
2019/03/25 Javascript
[02:52]DOTA2新手基础教程 米波
2014/01/21 DOTA
Python程序设计入门(2)变量类型简介
2014/06/16 Python
基于Python Numpy的数组array和矩阵matrix详解
2018/04/04 Python
Python写一个基于MD5的文件监听程序
2019/03/11 Python
Django使用redis缓存服务器的实现代码示例
2019/04/28 Python
python实现FTP循环上传文件
2020/03/20 Python
Pycharm中配置远程Docker运行环境的教程图解
2020/06/11 Python
KLOOK客路:发现更好玩的世界,预订独一无二的旅行体验
2016/12/16 全球购物
ProBikeKit英国:在线公路自行车之家
2017/02/10 全球购物
巴西网上药店:Drogaria Araujo
2021/01/06 全球购物
给导游的表扬信
2014/01/10 职场文书
给老婆道歉的话
2015/01/20 职场文书
学习雷锋精神活动总结
2015/02/06 职场文书
工会积极分子个人总结
2015/03/03 职场文书
学校食堂管理制度
2015/08/04 职场文书
2016廉洁从政心得体会
2016/01/19 职场文书
Matlab求解数组中的最大值及它所在的具体位置
2021/04/16 Python
为什么node.js不适合大型项目
2021/04/28 Javascript
JavaWeb 入门篇(3)ServletContext 详解 具体应用
2021/07/16 Java/Android
继承Win10缺点!教你关闭Win11烦人的网络搜索
2021/11/23 数码科技