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函数
Dec 06 PHP
一些PHP写的小东西
Dec 06 PHP
mysql 字段类型说明
Apr 27 PHP
php SQL防注入代码集合
Apr 25 PHP
为PHP初学者的8点有效建议
Nov 20 PHP
PHP输入流php://input介绍
Sep 18 PHP
PHP ? EasyUI DataGrid 资料存的方式介绍
Nov 07 PHP
基于php设计模式中单例模式的应用分析
May 15 PHP
PHP COOKIE及时生效的方法介绍
Feb 14 PHP
laravel + vue实现的数据统计绘图(今天、7天、30天数据)
Jul 31 PHP
PHP实现的pdo连接数据库并插入数据功能简单示例
Mar 30 PHP
php设计模式之享元模式分析【星际争霸游戏案例】
Mar 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开发环境配置记录
2011/01/14 PHP
php max_execution_time执行时间问题
2011/07/17 PHP
php正则表达式使用的详细介绍
2013/04/27 PHP
Thinkphp中volist标签mod控制一定记录的换行BUG解决方法
2014/11/04 PHP
Laravel学习教程之从入口到输出过程详解
2017/08/27 PHP
修改发贴的编辑功能
2007/03/07 Javascript
JQuery的ajax基础上的超强GridView展示
2009/09/18 Javascript
用jQuery toggleClass 实现鼠标移上变色
2014/05/14 Javascript
jQuery性能优化技巧分析
2015/02/20 Javascript
原生javascript实现的一个简单动画效果
2016/03/30 Javascript
JQuery DIV 动态隐藏和显示的方法
2016/06/23 Javascript
一步一步封装自己的HtmlHelper组件BootstrapHelper(二)
2016/09/14 Javascript
JavaScript中如何使用cookie实现记住密码功能及cookie相关函数介绍
2016/11/10 Javascript
第一次接触神奇的前端框架vue.js
2016/12/01 Javascript
js中的事件委托或是事件代理使用详解
2017/06/23 Javascript
Bootbox将后台JSON数据填充Form表单的实例代码
2018/09/10 Javascript
JavaScript 性能提升之路(推荐)
2019/04/10 Javascript
JavaScript展开操作符(Spread operator)详解
2019/07/20 Javascript
JS可断点续传文件上传实现代码解析
2020/07/30 Javascript
[02:26]2016国际邀请赛8月3日开战 中国军团出征西雅图
2016/08/02 DOTA
[50:34]VGJ.T vs Fnatic 2018国际邀请赛小组赛BO2 第二场 8.16
2018/08/17 DOTA
详解Python3中的迭代器和生成器及其区别
2018/10/09 Python
对pandas将dataframe中某列按照条件赋值的实例讲解
2018/11/29 Python
解决.ui文件生成的.py文件运行不出现界面的方法
2019/06/19 Python
python 公共方法汇总解析
2019/09/16 Python
Flask框架请求钩子与request请求对象用法实例分析
2019/11/07 Python
Python命令行click参数用法解析
2019/12/19 Python
Python 读取xml数据,cv2裁剪图片实例
2020/03/10 Python
Django Auth用户认证组件实现代码
2020/10/13 Python
Python基于staticmethod装饰器标示静态方法
2020/10/17 Python
HTML table 表格边框的实现思路
2019/10/12 HTML / CSS
英国最大的女性服装零售商:Dorothy Perkins
2017/03/30 全球购物
英国街头品牌:Bee Inspired Clothing
2018/02/12 全球购物
远程培训的心得体会
2014/09/01 职场文书
2014年英语教研组工作总结
2014/12/06 职场文书
2015年“7.11”世界人口日宣传活动方案
2015/05/06 职场文书