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环境配置 php5 mysql5 apache2 phpmyadmin安装与配置
Nov 17 PHP
PHP创建桌面快捷方式的实例代码
Feb 17 PHP
php生成html文件方法总结
Dec 01 PHP
php下载文件超时时间的设置方法
Oct 06 PHP
PHP处理Ajax请求与Ajax跨域问题
Feb 13 PHP
PHP 中常量的知识整理
Apr 14 PHP
php插件Xajax使用方法详解
Aug 31 PHP
PHP实现求两个字符串最长公共子串的方法示例
Nov 17 PHP
RSA实现JS前端加密与PHP后端解密功能示例
Aug 05 PHP
thinkPHP5框架路由常用知识点汇总
Sep 15 PHP
Yii2框架中一些折磨人的坑
Dec 15 PHP
php中配置文件保存修改操作 如config.php文件的读取修改等操作
May 12 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
一个简单的自动发送邮件系统(三)
2006/10/09 PHP
php缩放图片(根据宽高的等比例缩放)实例介绍
2013/06/09 PHP
PHP实现通过中文字符比率来判断垃圾评论的方法
2014/10/20 PHP
php实现复制移动文件的方法
2015/07/29 PHP
PHP输出XML格式数据的方法总结
2017/02/08 PHP
php利用云片网实现短信验证码功能的示例代码
2017/11/18 PHP
PHP多维数组排序array详解
2017/11/21 PHP
Yii 框架使用Forms操作详解
2020/05/18 PHP
向当前style sheet中插入一个新的style实现方法
2013/04/01 Javascript
JQuery的AJAX实现文件下载的小例子
2013/05/15 Javascript
js的Boolean对象初始值示例
2014/03/04 Javascript
常用DOM整理
2015/06/16 Javascript
javascript jquery对form元素的常见操作详解
2016/06/12 Javascript
使用contextMenu插件实现Bootstrap table弹出右键菜单
2017/02/20 Javascript
jQuery 中msgTips 顶部弹窗效果实现代码
2017/08/14 jQuery
jQuery实现图片下载代码
2019/07/18 jQuery
Vue.js中provide/inject实现响应式数据更新的方法示例
2019/10/16 Javascript
微信小程序封装多张图片上传api代码实例
2019/12/30 Javascript
修改Vue打包后的默认文件名操作
2020/08/12 Javascript
nodejs使用Sequelize框架操作数据库的实现
2020/10/21 NodeJs
nuxt.js服务端渲染中axios和proxy代理的配置操作
2020/11/06 Javascript
Python for Informatics 第11章 正则表达式(一)
2016/04/21 Python
PyQt5实现拖放功能
2018/04/25 Python
mac安装scrapy并创建项目的实例讲解
2018/06/13 Python
在python里协程使用同步锁Lock的实例
2019/02/19 Python
详解python中@的用法
2019/03/27 Python
python如何实现代码检查
2019/06/28 Python
对python中不同模块(函数、类、变量)的调用详解
2019/07/16 Python
python中使用you-get库批量在线下载bilibili视频的教程
2020/03/10 Python
canvas离屏技术与放大镜实现代码示例
2018/08/31 HTML / CSS
薇诺娜官方网上商城:专注敏感肌肤
2017/05/25 全球购物
财务出纳员岗位职责
2013/11/26 职场文书
绩效管理实施方案
2014/03/19 职场文书
亲子运动会的活动方案
2014/08/17 职场文书
小班上学期个人总结
2015/02/12 职场文书
医院志愿者活动总结
2015/05/06 职场文书