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 相关文章推荐
dede3.1分页文字采集过滤规则详说(图文教程)
Apr 03 PHP
20个PHP常用类库小结
Sep 11 PHP
PHP中比较时间大小实例
Aug 21 PHP
PHP读取txt文本文件并分页显示的方法
Mar 11 PHP
微信公众平台实现获取用户OpenID的方法
Apr 15 PHP
ThinkPHP框架分布式数据库连接方法详解
Mar 14 PHP
php无限级评论嵌套实现代码
Apr 18 PHP
PHP实现的mysql读写分离操作示例
May 22 PHP
php遍历目录下文件并按修改时间排序操作示例
Jul 12 PHP
PHP实现的文件浏览器功能简单示例
Sep 12 PHP
Thinkphp框架使用list_to_tree 实现无限级分类列出所有节点示例
Apr 04 PHP
如何重写Laravel异常处理类详解
Dec 20 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中的unicode和utf8编码
2015/06/10 PHP
PHP实现将MySQL重复ID二维数组重组为三维数组的方法
2016/08/01 PHP
PHP进程通信基础之信号
2017/02/19 PHP
Javascript学习笔记6 prototype的提出
2010/01/11 Javascript
原生javascript实现获取指定元素下所有后代元素的方法
2014/10/28 Javascript
JS创建对象几种不同方法详解
2016/03/01 Javascript
javascript HTML5文件上传FileReader API
2020/03/27 Javascript
前端学习笔记style,currentStyle,getComputedStyle的用法与区别
2016/05/28 Javascript
jQuery实现Table表格隔行变色及高亮显示当前选择行效果示例
2017/02/14 Javascript
Vue.js实现表格渲染的方法
2018/09/07 Javascript
微信小程序实现多行文字滚动
2020/11/18 Javascript
微信小程序实现点赞业务
2021/02/10 Javascript
[06:33]3.19 DOTA2发布会 海涛、冷冷、2009见证希望
2014/03/21 DOTA
Pycharm学习教程(5) Python快捷键相关设置
2017/05/03 Python
Python使用base64模块进行二进制数据编码详解
2018/01/11 Python
python使用knn实现特征向量分类
2018/12/26 Python
python requests 库请求带有文件参数的接口实例
2019/01/03 Python
对tensorflow中tf.nn.conv1d和layers.conv1d的区别详解
2020/02/11 Python
Python实现自动访问网页的例子
2020/02/21 Python
Jupyter notebook 启动闪退问题的解决
2020/04/13 Python
如何查看Django ORM执行的SQL语句的实现
2020/04/20 Python
Python变量格式化输出实现原理解析
2020/08/06 Python
css3中background新增的4个新的相关属性用法介绍
2013/09/26 HTML / CSS
Banana Republic英国官网:香蕉共和国,GAP集团旗下偏贵族风
2018/04/24 全球购物
Elizabeth Gage官网:英国最好的珠宝设计之一
2020/09/26 全球购物
学生会主席演讲稿
2014/04/25 职场文书
财务会计实训报告
2014/11/05 职场文书
讲文明倡议书
2015/04/29 职场文书
2015年卫生局工作总结
2015/07/24 职场文书
关于五一放假的通知
2015/08/18 职场文书
高中语文教材(文学文化常识大全一)
2019/08/13 职场文书
晶体管来复再生式二管收音机
2021/04/22 无线电
Python字符串对齐方法使用(ljust()、rjust()和center())
2021/04/26 Python
解析laravel使用workerman用户交互、服务器交互
2021/04/28 PHP
sql中mod()函数取余数的用法
2021/05/29 SQL Server
MySQL 常见的数据表设计误区汇总
2021/06/07 MySQL