《PHP編程:PHP下使用mysqli的函數連接mysql出現warning: mysqli::real》要點:
本文介紹了PHP編程:PHP下使用mysqli的函數連接mysql出現warning: mysqli::real,希望對您有用。如果有疑問,可以聯系我們。
背景:把mysql換成mysqli時出現,連接數過多,其實際上并不是,原因是我挪動了一下php的sock文件位置導致,因這幾個socket修改沒有修改完全,于是出現了too many connections ,從mysql里show processlist并沒有發現真的有連接,其實用tshark抓下包估計能看到(http://justwinit.cn/post/7458/),并沒有發出哀求,而估計是mysqli的客戶端自己報出來的,別看這個問題小,搞了老半天,都想重新安裝Php了,發現原來是路徑寫錯了同時mysqli的客戶端提示連接數過多的誤提示導致方向走錯了.如下:PHP實戰
[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:PHP實戰
[root@iZ25z0ugwgtZ etc]# service php-fpm restart Gracefully shutting down php-fpm . done Starting php-fpm done
______________________排查要點如下_______________________________PHP實戰
warning: mysqli::real_connect(): (hy000/1040): too many connections in:PHP實戰
呈現場景 :手動編譯安裝mysql,并制定安裝位置,php以localhost方式連接mysqlPHP實戰
原因闡發 :手動編譯安裝制定位置后所有的mysql文件都在制定的目錄或者data目錄下面,php默認只會尋找/temp/mysql.sock找這個sock文件,所以會導致sock文件無法找到.PHP實戰
解決辦法 :PHP實戰
1.給sock文件做個軟鏈PHP實戰
ln -s /data/mysqldb/mysql.sock /tmp/mysql.sock;PHP實戰
又或PHP實戰
2.改動php的默認mysql.sock連接地址PHP實戰
mysql.default_socket=/data/mysqldb/mysql.sockPHP實戰
3.使用tcp socket的方式進行銜接PHP實戰
mysql('127.0.0.1','username','passwod');PHP實戰
下面給年夜家介紹PHP mysql_connect() 函數PHP實戰
界說和用法PHP實戰
mysql_connect() 函數打開非持久的 MySQL 銜接.PHP實戰
語法PHP實戰
mysql_connect(server,user,pwd,newlink,clientflag)
參數 | 描述 |
---|---|
server |
可選.劃定要連接的服務器.PHP實戰 可以包含端口號,例如 "hostname:port",或者到本地套接字的路徑,例如對于 localhost 的 ":/path/to/socket".PHP實戰 如果 PHP 指令 mysql.default_host 未界說(默認情況),則默認值是 'localhost:3306'.PHP實戰 |
user | 可選.用戶名.默認值是服務器進程所有者的用戶名. |
pwd | 可選.暗碼.默認值是空暗碼. |
newlink | 可選.如果用同樣的參數第二次調用 mysql_connect(),將不會建立新連接,而將返回已經打開的連接標識.參數 new_link 改變此行為并使 mysql_connect() 總是打開新的連接,甚至當 mysql_connect() 曾在前面被用同樣的參數調用過. |
clientflag |
可選.client_flags 參數可以是以下常量的組合:PHP實戰
|
返回值PHP實戰
如果勝利,則返回一個 MySQL 連接標識,失敗則返回 FALSE.PHP實戰
提醒和注釋PHP實戰
注釋:腳本一結束,到服務器的連接就被關閉,除非之前已經明確調用 mysql_close() 關閉了.
提示:要創立一個持久連接,請使用 mysql_pconnect() 函數.PHP實戰
例子PHP實戰
<必修php $con = mysql_connect("localhost","mysql_user","mysql_pwd"); if (!$con) { die('Could not connect: ' . mysql_error()); } // 一些代碼... mysql_close($con); 必修>
歡迎參與《PHP編程:PHP下使用mysqli的函數連接mysql出現warning: mysqli::real》討論,分享您的想法,維易PHP學院為您提供專業教程。
轉載請注明本頁網址:
http://www.snjht.com/jiaocheng/7557.html