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 正则表达式小结
Aug 31 PHP
探讨:使用XMLSerialize 序列化与反序列化
Jun 08 PHP
ThinkPHP中pathinfo的访问模式、路径访问模式及URL重写总结
Aug 23 PHP
PHP会话控制:Session与Cookie详解
Sep 27 PHP
php+jQuery.uploadify实现文件上传教程
Dec 26 PHP
9条PHP编程小知识及易犯的小错误
Jan 22 PHP
新浪微博OAuth认证和储存的主要过程详解
Mar 27 PHP
php实现mysql数据库连接操作及用户管理
Nov 08 PHP
tp框架(thinkPHP)实现三次登陆密码错误之后锁定账号功能示例
May 24 PHP
PHP回调函数简单用法示例
May 08 PHP
Yii2.0框架behaviors方法使用实例分析
Sep 30 PHP
TP5框架实现上传多张图片的方法分析
Mar 29 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数组函数序列之array_search()- 按元素值返回键名
2011/11/04 PHP
IIS6.0中配置php服务全过程解析
2013/08/07 PHP
PHP is_subclass_of函数的一个BUG和解决方法
2014/06/01 PHP
php生成图片验证码的实例讲解
2015/08/03 PHP
php加密解密字符串示例
2016/10/13 PHP
PHP使用xpath解析XML的方法详解
2017/05/20 PHP
jQuery Ajax 实例全解析
2011/04/20 Javascript
javascript的offset、client、scroll使用方法详解
2012/12/25 Javascript
javascript省市区三级联动下拉框菜单实例演示
2015/11/29 Javascript
微信小程序 122100版本更新问题解决方案
2016/12/22 Javascript
拖动时防止选中
2017/02/03 Javascript
validationEngine 表单验证插件使用实例代码
2017/06/15 Javascript
vue.js移动端app实战1:初始配置详解
2017/07/24 Javascript
基于axios封装fetch方法及调用实例
2018/02/05 Javascript
Vue中JS动画与Velocity.js的结合使用
2019/02/13 Javascript
jquery分页优化操作实例分析
2019/08/23 jQuery
VsCode与Node.js知识点详解
2019/09/05 Javascript
vue实现淘宝购物车功能
2020/04/20 Javascript
人工智能最火编程语言 Python大战Java!
2017/11/13 Python
Python分析学校四六级过关情况
2017/11/22 Python
Python 查看文件的读写权限方法
2018/01/23 Python
Python多线程threading和multiprocessing模块实例解析
2018/01/29 Python
对numpy中轴与维度的理解
2018/04/18 Python
利用Python半自动化生成Nessus报告的方法
2019/03/19 Python
django-rest-swagger的优化使用方法
2019/08/29 Python
基于Python解密仿射密码
2019/10/21 Python
python hash每次调用结果不同的原因
2019/11/21 Python
解决Python3.8用pip安装turtle-0.0.2出现错误问题
2020/02/11 Python
Python爬虫制作翻译程序的示例代码
2021/02/22 Python
软件配置管理有什么好处
2015/04/15 面试题
居委会个人对照检查材料思想汇报
2014/09/29 职场文书
作风整顿个人剖析材料
2014/10/06 职场文书
介绍信的写法
2015/01/31 职场文书
2016年党风廉政建设承诺书
2016/03/25 职场文书
如何做好员工培训计划?
2019/07/09 职场文书
Linux中一对多配置日志服务器的详细步骤
2022/07/23 Servers