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 03 PHP
php 生成WML页面方法详解
Aug 09 PHP
简单的PHP留言本实例代码
May 09 PHP
php在线代理转向代码
May 05 PHP
Laravel框架学习笔记(一)环境搭建
Oct 15 PHP
thinkphp模板继承实例简述
Nov 26 PHP
php把数组值转换成键的方法
Jul 13 PHP
利用PHP如何写APP接口详解
Aug 23 PHP
PHP连接MySQL数据库并以json格式输出
May 21 PHP
PHP实现SMTP邮件的发送实例
Sep 27 PHP
PHP数组遍历的几种常见方式总结
Feb 15 PHP
laravel5 Eloquent 实现事务方式
Oct 21 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接口和抽象类使用示例详解
2014/03/02 PHP
Yii框架实现对数据库的CURD操作示例
2019/09/03 PHP
php连接mysql之mysql_connect()与mysqli_connect()的区别
2020/07/19 PHP
xtree.js 代码
2007/03/13 Javascript
麦鸡的TAB切换功能结合了javascript和css
2007/12/17 Javascript
Prototype Array对象 学习
2009/07/19 Javascript
js不完美解决click和dblclick事件冲突问题
2012/07/16 Javascript
Jquery 跨域访问 Lightswitch OData Service的方法
2013/09/11 Javascript
jQuery淡入淡出元素让其效果更为生动
2014/09/01 Javascript
jQuery中:hidden选择器用法实例
2014/12/30 Javascript
js树插件zTree获取所有选中节点数据的方法
2015/01/28 Javascript
Highcharts 多个Y轴动态刷新数据的实现代码
2016/05/28 Javascript
javascript淘宝主图放大镜功能
2016/10/20 Javascript
JS 实现Base64编码与解码实例详解
2016/11/07 Javascript
利用Js的console对象,在控制台打印调式信息测试Js的实现
2016/11/26 Javascript
jquery实现手机端单店铺购物车结算删除功能
2017/02/22 Javascript
node使用Koa2搭建web项目的方法
2017/10/17 Javascript
vue实现动态按钮功能
2019/05/13 Javascript
JavaScript工具库MyTools详解
2020/01/01 Javascript
详解vue中使用transition和animation的实例代码
2020/12/12 Vue.js
详解python发送各类邮件的主要方法
2016/12/22 Python
使用Django Form解决表单数据无法动态刷新的两种方法
2017/07/14 Python
Python地图绘制实操详解
2019/03/04 Python
Django Model中字段(field)的各种选项说明
2020/05/19 Python
Python如何读取、写入CSV数据
2020/07/28 Python
JustFab加拿大:女鞋、靴子、手袋和服装在线
2018/05/18 全球购物
美国温暖商店:The Warming Store
2018/12/15 全球购物
匡威西班牙官网:Converse西班牙
2019/10/01 全球购物
个人实习生的自我评价
2014/02/16 职场文书
幼儿教师寄语集锦
2014/04/03 职场文书
代办委托书怎样写
2014/04/08 职场文书
租房合同协议书
2014/04/09 职场文书
员工离职通知函
2015/04/25 职场文书
解决 Redis 秒杀超卖场景的高并发
2022/04/12 Redis
Windows11 Insider Preview Build 25206今日发布 更新内容汇总
2022/09/23 数码科技
修改Nginx配置返回指定content-type的方法
2022/09/23 Servers