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可能遇到的问题“无法载入mysql扩展” 的解决方法
Apr 16 PHP
php获取url字符串截取路径的文件名和扩展名的函数
Jan 22 PHP
php下连接ftp实现文件的上传、下载、删除文件实例代码
Jun 03 PHP
php中session_unset与session_destroy的区别分析
Jun 16 PHP
php数组函数序列之each() - 获取数组当前内部指针所指向元素的键名和键值,并将指针移到下一位
Oct 31 PHP
php实现的发送带附件邮件类实例
Sep 22 PHP
PHP页面转UTF-8中文编码乱码的解决办法
Oct 20 PHP
详解PHP的Yii框架中的Controller控制器
Mar 29 PHP
mysql_escape_string()函数用法分析
Apr 25 PHP
php对微信支付回调处理的方法
Aug 23 PHP
PHP如何获取Cookie并实现模拟登录
Jul 16 PHP
Laravel相关的一些故障解决
Aug 19 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编程效率的53个要点(经验小结)
2010/09/04 PHP
php Rename 更改文件、文件夹名称
2011/05/24 PHP
php读取本地文件常用函数(fopen与file_get_contents)
2013/09/09 PHP
php实现memcache缓存示例讲解
2013/12/04 PHP
Thinkphp中volist标签mod控制一定记录的换行BUG解决方法
2014/11/04 PHP
Windows2003下php5.4安装配置教程(IIS)
2016/06/30 PHP
php curl操作API接口类完整示例
2019/05/21 PHP
JS request函数 用来获取url参数
2010/05/17 Javascript
JavaScript 面向对象编程(2) 定义类
2010/05/18 Javascript
JS无法捕获滚动条上的mouse up事件的原因猜想
2012/03/21 Javascript
ExtJS4中使用mixins实现多继承示例
2013/12/03 Javascript
jQuery窗口、文档、网页各种高度的精确理解
2014/07/02 Javascript
浅谈window对象的scrollBy()方法
2015/07/15 Javascript
jQuery Mobile弹出窗、弹出层知识汇总
2016/01/05 Javascript
原生和jQuery的ajax用法详解
2017/01/23 Javascript
在vscode中统一vue编码风格的方法
2018/02/22 Javascript
对类Vue的MVVM前端库的实现代码
2018/09/07 Javascript
vue表单验证你真的会了吗?vue表单验证(form)validate
2019/04/07 Javascript
小程序rich-text组件如何改变内部img图片样式的方法
2019/05/22 Javascript
layui文件上传控件带更改后数据传值的方法
2019/09/23 Javascript
vue的hash值原理也是table切换实例代码
2020/12/14 Vue.js
[01:25:09]2014 DOTA2国际邀请赛中国区预选赛 5 23 CIS VS DT第二场
2014/05/24 DOTA
python3使用urllib示例取googletranslate(谷歌翻译)
2014/01/23 Python
pygame学习笔记(5):游戏精灵
2015/04/15 Python
python批量修改文件编码格式的方法
2018/05/31 Python
tensorflow 用矩阵运算替换for循环 用tf.tile而不写for的方法
2018/07/27 Python
Python异常处理操作实例详解
2018/08/28 Python
python 整数越界问题详解
2019/06/27 Python
python利用itertools生成密码字典并多线程撞库破解rar密码
2019/08/12 Python
css3弹性盒模型实例介绍
2013/05/27 HTML / CSS
html5 sessionStorage会话存储_动力节点Java学院整理
2017/07/06 HTML / CSS
村长党的群众路线教育实践活动个人对照检查材料
2014/09/23 职场文书
资料员岗位职责范本
2015/04/13 职场文书
浅谈JS的原型和原型链
2021/06/04 Javascript
Win11怎么进入安全模式?Windows 11进入安全模式的方法
2021/11/21 数码科技
教你修复 Win11应用商店加载空白问题
2021/12/06 数码科技