PHP下使用mysqli的函數(shù)連接mysql出現(xiàn)warning: mysqli::real_connect(): (hy000/1040): ...
背景:把mysql換成mysqli時(shí)出現(xiàn),連接數(shù)過多,其實(shí)際上并不是,原因是我挪動(dòng)了一下php的sock文件位置導(dǎo)致,因這幾個(gè)socket修改沒有修改完全,于是出現(xiàn)了too many connections ,從mysql里show processlist并沒有發(fā)現(xiàn)真的有連接,其實(shí)用tshark抓下包估計(jì)能看到(http://justwinit.cn/post/7458/),并沒有發(fā)出請(qǐng)求,而估計(jì)是mysqli的客戶端自己報(bào)出來的,別看這個(gè)問題小,搞了老半天,都想重新安裝Php了,發(fā)現(xiàn)原來是路徑寫錯(cuò)了同時(shí)mysqli的客戶端提示連接數(shù)過多的誤提示導(dǎo)致方向走錯(cuò)了。如下:
[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 //這個(gè)位置被挪動(dòng)到,/data/runsock/mysqlsock/mysql.sock導(dǎo)致。
修改后記得重啟動(dòng)php-fpm:
[root@iZ25z0ugwgtZ etc]# service php-fpm restart Gracefully shutting down php-fpm . done Starting php-fpm done
______________________排查要點(diǎn)如下_______________________________
warning: mysqli::real_connect(): (hy000/1040): too many connections in:
出現(xiàn)場(chǎng)景 :手動(dòng)編譯安裝mysql,并制定安裝位置,php以localhost方式連接mysql
原因分析 :手動(dòng)編譯安裝制定位置后所有的mysql文件都在制定的目錄或者data目錄下面,php默認(rèn)只會(huì)尋找/temp/mysql.sock找這個(gè)sock文件,所以會(huì)導(dǎo)致sock文件無法找到。
解決方法 :
1.給sock文件做個(gè)軟鏈
ln -s /data/mysqldb/mysql.sock /tmp/mysql.sock;
或者
2.修改php的默認(rèn)mysql.sock連接地址
mysql.default_socket=/data/mysqldb/mysql.sock
3.使用tcp socket的方式進(jìn)行連接
mysql('127.0.0.1','username','passwod');
下面給大家介紹PHP mysql_connect() 函數(shù)
定義和用法
mysql_connect() 函數(shù)打開非持久的 MySQL 連接。
語法
mysql_connect(server,user,pwd,newlink,clientflag)
參數(shù) | 描述 |
---|---|
server |
可選。規(guī)定要連接的服務(wù)器。 可以包括端口號(hào),例如 "hostname:port",或者到本地套接字的路徑,例如對(duì)于 localhost 的 ":/path/to/socket"。 如果 PHP 指令 mysql.default_host 未定義(默認(rèn)情況),則默認(rèn)值是 'localhost:3306'。 |
user | 可選。用戶名。默認(rèn)值是服務(wù)器進(jìn)程所有者的用戶名。 |
pwd | 可選。密碼。默認(rèn)值是空密碼。 |
newlink | 可選。如果用同樣的參數(shù)第二次調(diào)用 mysql_connect(),將不會(huì)建立新連接,而將返回已經(jīng)打開的連接標(biāo)識(shí)。參數(shù) new_link 改變此行為并使 mysql_connect() 總是打開新的連接,甚至當(dāng) mysql_connect() 曾在前面被用同樣的參數(shù)調(diào)用過。 |
clientflag |
可選。client_flags 參數(shù)可以是以下常量的組合:
|
返回值
如果成功,則返回一個(gè) MySQL 連接標(biāo)識(shí),失敗則返回 FALSE。
提示和注釋
注釋:腳本一結(jié)束,到服務(wù)器的連接就被關(guān)閉,除非之前已經(jīng)明確調(diào)用 mysql_close() 關(guān)閉了。
提示:要?jiǎng)?chuàng)建一個(gè)持久連接,請(qǐng)使用 mysql_pconnect() 函數(shù)。
例子
<?php $con = mysql_connect("localhost","mysql_user","mysql_pwd"); if (!$con) { die('Could not connect: ' . mysql_error()); } // 一些代碼... mysql_close($con); ?>
相關(guān)文章
Laravel實(shí)現(xiàn)短信注冊(cè)的示例代碼
這篇文章主要介紹了Laravel實(shí)現(xiàn)短信注冊(cè)的示例代碼,使用云片短信平臺(tái),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-05-05codeigniter上傳圖片不能正確識(shí)別圖片類型問題解決方法
這篇文章主要介紹了codeigniter上傳圖片不能正確識(shí)別圖片類型問題解決方法,這是一個(gè)不太常見的問題,但是遇到了的話會(huì)卡人很久,需要的朋友可以參考下2014-07-07ThinkPHP3.1新特性之對(duì)分組支持的改進(jìn)與完善概述
這篇文章主要介紹了ThinkPHP3.1對(duì)分組支持的改進(jìn),需要的朋友可以參考下2014-06-06實(shí)例分析PHP將字符串轉(zhuǎn)換成數(shù)字的方法
在本篇文章里我們給大家分享的是關(guān)于PHP將字符串轉(zhuǎn)換成數(shù)字的方法和相關(guān)知識(shí)點(diǎn),有興趣的朋友們學(xué)習(xí)下。2019-01-01PHP簡單實(shí)現(xiàn)圖片格式轉(zhuǎn)換(jpg轉(zhuǎn)png,gif轉(zhuǎn)png等)
這篇文章主要介紹了PHP簡單實(shí)現(xiàn)圖片格式轉(zhuǎn)換(jpg轉(zhuǎn)png,gif轉(zhuǎn)png等),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-10-10利用php的ob緩存機(jī)制實(shí)現(xiàn)頁面靜態(tài)化方法
下面小編就為大家?guī)硪黄胮hp的ob緩存機(jī)制實(shí)現(xiàn)頁面靜態(tài)化方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-07-07