解決「無法透過Socket 連線到本機MySQL 伺服器」錯誤
錯誤「無法透過Socket 連線到本機MySQL 伺服器」當嘗試使用PHP MySQLi 類別連接到MySQL 資料庫時,會出現「socket 'MySQL' (2)」。此錯誤表示正在嘗試 Unix 域套接字,而不是 TCP/IP 連線。
了解 MySQL 連線的 Unix 網域套接字
指定「localhost」時作為主機,MySQL 用戶端程式庫預設使用 Unix 網域套接字進行連線。與 TCP/IP 連線不同,Unix 域套接字利用作業系統內的套接字檔案與 MySQL 建立通訊。
解決連線問題
有多種方法可以解決此連線問題:
1.指定TCP/IP 連線:
要強制使用TCP/IP 連線而不是Unix網域套接字,請在連線時使用「127.0.0.1」作為主機。即使使用“localhost”,這也可確保 TCP/IP 連線。
2.設定Unix 域套接字:
如果更喜歡使用Unix 域套接字,請在MySQL 設定檔「my.cnf」中找到套接字的路徑,並將PHP 的「mysqli.default_socket」設定為該路徑。
3。在 PHP 腳本中明確設定套接字:
開啟連線時也可以直接在 PHP 腳本中設定套接字。例如:
$db = new MySQLi('localhost', 'kamil', '***', '', 0, '/var/run/mysqld/mysqld.sock');
選擇連接方式
最佳連接方式取決於特定環境。 Unix 網域套接字可以更快、更安全,但它們需要設定套接字路徑。另一方面,TCP/IP 連線不需要特殊配置,但可能會比較慢。
以上是為什麼無法透過 Socket 連接到本機 MySQL 伺服器,如何修復?的詳細內容。更多資訊請關注PHP中文網其他相關文章!