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生成随机密码的三种方法小结
Sep 04 PHP
PHP程序员最常犯的11个MySQL错误小结
Nov 20 PHP
PHP安全配置详细说明
Sep 26 PHP
Yii PHP Framework实用入门教程(详细介绍)
Jun 18 PHP
zf框架的registry(注册表)使用示例
Mar 13 PHP
在PHP模板引擎smarty生成随机数的方法和math函数详解
Apr 24 PHP
PHP图片处理之图片背景、画布操作
Nov 19 PHP
CI(CodeIgniter)框架实现图片上传的方法
Mar 24 PHP
深入理解Yii2.0乐观锁与悲观锁的原理与使用
Jul 26 PHP
基于ThinkPHP5.0实现图片上传插件
Sep 25 PHP
laravel 框架执行流程与原理简单分析
Feb 01 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输出xml格式字符串(用的这个)
2012/07/12 PHP
php读取csv文件并输出的方法
2015/03/14 PHP
PHP查找数值数组中不重复最大和最小的10个数的方法
2015/04/20 PHP
php遍历、读取文件夹中图片并分页显示图片的方法
2016/11/15 PHP
PHP设计模式之适配器模式(Adapter)原理与用法详解
2019/12/12 PHP
从新浪弄下来的全屏广告代码 与使用说明
2007/03/15 Javascript
jquery的Tooltip插件 qtip使用详细说明
2010/09/08 Javascript
将string解析为json的几种方式小结
2010/11/11 Javascript
jQuery EasyUI API 中文文档 - Tree树使用介绍
2011/11/19 Javascript
js正文内容高亮效果的实现方法
2013/06/30 Javascript
js判断输入是否为数字的具体实例
2013/08/03 Javascript
一个获取第n个元素节点的js函数
2014/09/02 Javascript
JavaScript数组常用方法
2015/03/02 Javascript
基于jQuery插件jqzoom实现的图片放大镜效果示例
2017/01/23 Javascript
vue动态生成dom并且自动绑定事件
2017/04/19 Javascript
详解Vue-cli代理解决跨域问题
2017/09/27 Javascript
vue学习之mintui picker选择器实现省市二级联动示例
2017/10/12 Javascript
web前端页面生成exe可执行文件的方法
2018/02/08 Javascript
在 Vue 应用中使用 Netlify 表单功能的方法详解
2019/06/03 Javascript
NodeJs生成sitemap站点地图的方法示例
2019/06/11 NodeJs
Vue中img的src是动态渲染时不显示的解决
2019/11/14 Javascript
微信小程序添加插屏广告并设置显示频率(一天一次)
2019/12/06 Javascript
python函数形参用法实例分析
2015/08/04 Python
深入理解Python装饰器
2016/07/27 Python
利用python的socket发送http(s)请求方法示例
2018/05/07 Python
python生成ppt的方法
2018/06/07 Python
django 将model转换为字典的方法示例
2018/10/16 Python
解决django服务器重启端口被占用的问题
2019/07/26 Python
Python cookie的保存与读取、SSL讲解
2020/02/17 Python
意大利奢侈品牌在线精品店:Jole.it
2020/11/23 全球购物
考察现实表现材料
2014/05/19 职场文书
中药学专业毕业生推荐信
2014/07/10 职场文书
2014年精神文明建设工作总结
2014/11/19 职场文书
党纪处分决定书
2015/06/24 职场文书
关于Spring配置文件加载方式变化引发的异常详解
2022/01/18 Java/Android
中国十大神话动漫电影排行榜 哪吒登顶 白蛇缘起排第七
2022/03/21 国漫