溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

PHP下使用mysqli的函數(shù)連接mysql出現(xiàn)warning: mysqli::real_connect(): (hy000/1040)怎么解決

發(fā)布時(shí)間:2021-09-01 22:51:48 來源:億速云 閱讀:198 作者:chen 欄目:開發(fā)技術(shù)

這篇文章主要介紹“PHP下使用mysqli的函數(shù)連接mysql出現(xiàn)warning: mysqli::real_connect(): (hy000/1040)怎么解決”,在日常操作中,相信很多人在PHP下使用mysqli的函數(shù)連接mysql出現(xiàn)warning: mysqli::real_connect(): (hy000/1040)怎么解決問題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”PHP下使用mysqli的函數(shù)連接mysql出現(xiàn)warning: mysqli::real_connect(): (hy000/1040)怎么解決”的疑惑有所幫助!接下來,請(qǐng)跟著小編一起來學(xué)習(xí)吧!

背景:把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 連接。

語(yǔ)法

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ù)可以是以下常量的組合:

  • MYSQL_CLIENT_SSL - 使用 SSL 加密

  • MYSQL_CLIENT_COMPRESS - 使用壓縮協(xié)議

  • MYSQL_CLIENT_IGNORE_SPACE - 允許函數(shù)名后的間隔

  • MYSQL_CLIENT_INTERACTIVE - 允許關(guān)閉連接之前的交互超時(shí)非活動(dòng)時(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)于“PHP下使用mysqli的函數(shù)連接mysql出現(xiàn)warning: mysqli::real_connect(): (hy000/1040)怎么解決”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注億速云網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI