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 相关文章推荐
桌面中心(一)创建数据库
Oct 09 PHP
Php做的端口嗅探器--可以指定网站和端口
Oct 09 PHP
在字符串指定位置插入一段字符串的php代码
Feb 16 PHP
php 生成自动创建文件夹并上传文件的示例代码
Mar 07 PHP
Mac OS下配置PHP+MySql环境
Feb 25 PHP
PHP下载生成的csv文件及问题总结
Aug 06 PHP
PHP程序员不应该忽略的3点
Oct 09 PHP
Zend Framework教程之资源(Resources)用法实例详解
Mar 14 PHP
php调用自己java程序的方法详解
May 13 PHP
php基于Redis消息队列实现的消息推送的方法
Nov 28 PHP
使用laravel的migrate创建数据表的方法
Sep 30 PHP
laravel 多图上传及图片的存储例子
Oct 14 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
ThinkPHP3.1之D方法实例详解
2014/06/20 PHP
PHP实现的简单分页类及用法示例
2016/05/06 PHP
JS限制Textarea文本域字符个数的具体实现
2013/08/02 Javascript
JavaScript学习笔记之Cookie对象
2015/01/22 Javascript
JavaScript中字面量与函数的基本使用知识
2015/10/20 Javascript
jQuery使用Selectator插件实现多选下拉列表过滤框(附源码下载)
2016/04/08 Javascript
Vue中引入样式文件的方法
2017/08/18 Javascript
JQuery 又谈ajax局部刷新
2017/11/27 jQuery
jquery如何实现点击空白处隐藏元素
2017/12/05 jQuery
vue2.0自定义指令示例代码详解
2019/04/25 Javascript
angularjs请求数据的方法示例
2019/08/06 Javascript
Vue CLI项目 axios模块前后端交互的使用(类似ajax提交)
2019/09/01 Javascript
js实现数字从零慢慢增加到指定数字示例
2019/11/07 Javascript
解决vue使用vant下拉框van-dropdown-item 绑定title值不变问题
2020/08/05 Javascript
[50:12]EG vs Fnatic 2018国际邀请赛小组赛BO2 第二场 8.19
2018/08/21 DOTA
python OpenCV学习笔记之绘制直方图的方法
2018/02/08 Python
python实现判断一个字符串是否是合法IP地址的示例
2018/06/04 Python
pandas值替换方法
2018/07/10 Python
python正则爬取某段子网站前20页段子(request库)过程解析
2019/08/10 Python
详解Python中import机制
2020/09/11 Python
如何使用Python进行PDF图片识别OCR
2021/01/22 Python
详解使用CSS3的@media来编写响应式的页面
2017/11/01 HTML / CSS
html5 学习简单的拾色器
2010/09/03 HTML / CSS
突袭HTML5之Javascript API扩展5—其他扩展(应用缓存/服务端消息/桌面通知)
2013/01/31 HTML / CSS
Canvas中设置width与height的问题浅析
2018/11/01 HTML / CSS
Aerosoles爱柔仕官网:美国舒软女鞋品牌
2017/07/17 全球购物
运动会广播稿500字
2014/01/28 职场文书
高中生的自我评价
2014/03/04 职场文书
十佳护士先进事迹
2014/05/08 职场文书
银行领导班子四风对照检查材料
2014/09/27 职场文书
学习保证书100字
2015/02/26 职场文书
小学见习报告
2015/06/23 职场文书
MySQL创建高性能索引的全步骤
2021/05/02 MySQL
Redis 的查询很快的原因解析及Redis 如何保证查询的高效
2022/03/16 Redis
HTML5之高度塌陷问题的解决
2022/06/01 HTML / CSS
vue实现简易音乐播放器
2022/08/14 Vue.js