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查询域名状态whois的类
Nov 25 PHP
php 提速工具eAccelerator 配置参数详解
May 16 PHP
php批量更改数据库表前缀实现方法
Oct 26 PHP
PHP文件大小格式化函数合集
Mar 10 PHP
PHP has encountered a Stack overflow问题解决方法
Nov 03 PHP
php截取html字符串及自动补全html标签的方法
Jan 15 PHP
Php-Redis安装测试笔记
Mar 05 PHP
Smarty保留变量用法分析
May 23 PHP
php版微信自动获取收货地址api用法示例
Sep 22 PHP
利用Laravel生成Gravatar头像地址的优雅方法
Dec 30 PHP
使用PHPUnit进行单元测试并生成代码覆盖率报告的方法
Mar 08 PHP
laravel框架模型、视图与控制器简单操作示例
Oct 10 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
打造计数器DIY三步曲(下)
2006/10/09 PHP
php中jQuery插件autocomplate的简单使用笔记
2012/06/14 PHP
php使用变量动态创建类的对象用法示例
2017/02/06 PHP
纯CSS3实现质感细腻丝滑按钮
2021/03/09 HTML / CSS
jquery 简单导航实现代码
2009/09/11 Javascript
JQuery 插件模板 制作jquery插件的朋友可以参考下
2010/03/17 Javascript
jquery对table中各数据的增加、保存、删除操作示例
2014/05/14 Javascript
跟我学习javascript的this关键字
2020/05/28 Javascript
jQuery的Each比JS原生for循环性能慢很多的原因
2016/07/05 Javascript
Angularjs中controller的三种写法分享
2016/09/21 Javascript
原生JS实现匀速图片轮播动画
2016/10/18 Javascript
JavaScript实现打地鼠小游戏
2020/04/23 Javascript
Vue完整项目构建(进阶篇)
2018/02/10 Javascript
JavaScript引用类型之基本包装类型实例分析【Boolean、Number和String】
2018/08/09 Javascript
使用FormData实现上传多个文件
2018/12/04 Javascript
详解vue的双向绑定原理及实现
2019/05/05 Javascript
详解如何搭建mpvue框架搭配vant组件库的小程序项目
2019/05/16 Javascript
微信小程序 腾讯地图SDK 获取当前地址实现解析
2019/08/12 Javascript
js实现聊天对话框
2020/02/08 Javascript
jquery向后台提交数组的代码分析
2020/02/20 jQuery
vue项目使用高德地图的定位及关键字搜索功能的实例代码(踩坑经验)
2020/03/07 Javascript
vue项目打包后请求地址错误/打包后跨域操作
2020/11/04 Javascript
VueCli生产环境打包部署跨域失败的解决
2020/11/13 Javascript
[33:28]完美世界DOTA2联赛PWL S3 PXG vs GXR 第三场 12.19
2020/12/24 DOTA
Python闭包实现计数器的方法
2015/05/05 Python
Python内置函数 next的具体使用方法
2017/11/24 Python
最小二乘法及其python实现详解
2020/02/24 Python
python GUI库图形界面开发之PyQt5打开保存对话框QFileDialog详细使用方法与实例
2020/02/27 Python
CSS3制作炫酷的下拉菜单及弹起式选单的实例分享
2016/05/17 HTML / CSS
HTML5、Select下拉框右边加图标的实现代码(增进用户体验)
2017/10/16 HTML / CSS
法律七进实施方案
2014/03/15 职场文书
护士长竞聘书
2014/03/31 职场文书
2014年党员自我评价材料
2014/09/22 职场文书
音乐剧猫观后感
2015/06/04 职场文书
如何利用map实现Nginx允许多个域名跨域
2021/03/31 Servers
MySQL视图概念以及相关应用
2022/04/19 MySQL