如何修復錯誤 1130 (HY000) 主機不允許連線到此 MySQL 伺服器?


介紹

如果您是 IT 專業人員或網站開發人員,那麼您很可能在工作中遇到過 MySQL 錯誤程式碼 1130 (HY000)。錯誤訊息通常顯示為“主機 'host_name' 不允許連線到此 MySQL 伺服器”。眾所周知,MySQL 是一種流行的開源關係資料庫管理系統,全球數百萬使用者依賴它。但是,在能夠使用 MySQL 之前,必須配置一些設定才能使其正常執行。

在設定 MySQL 伺服器時,配置主機訪問列表是必不可少的步驟之一。此列表指定哪些計算機或網路可以連線和訪問資料庫伺服器。

修復錯誤的重要性

如前所述,錯誤 1130 (HY000) 表示您的計算機和 MySQL 伺服器之間沒有通訊。如果沒有這兩個實體之間的正確通訊,則儲存在伺服器上資料庫中的所有資料都將無法訪問。在當今資料儲存和管理對企業和個人都至關重要的數字時代,這可能導致收入損失或開發依賴於此類資料庫的應用程式所投入的時間損失。

丟失重要資料的可能性突出了為什麼在出現錯誤 1130 (HY000) 時必須儘快修復它。

瞭解錯誤

如果您使用 MySQL,則在嘗試連線到 MySQL 伺服器時可能遇到過錯誤 1130 (HY000)。此錯誤訊息表示主機不允許連線到 MySQL 伺服器。通常,此錯誤訊息還伴隨錯誤程式碼以及對錯誤原因的描述。

錯誤 1130 (HY000) 的定義

錯誤 1130 (HY000) 是一種 MySQL 連線錯誤,當主機不允許連線到 MySQL 伺服器時發生。此錯誤通常發生在嘗試從一臺機器到另一臺機器或兩臺不同的虛擬機器之間建立遠端連線時。

錯誤的可能原因

錯誤 1130 (HY000) 有幾個潛在的原因。一個可能的原因可能是由於連線嘗試使用了不正確的登入憑據。另一個常見的原因可能是由於網路防火牆設定或 MySQL 的使用者表中對 IP 地址的限制。

如何識別錯誤的原因

識別和解決與錯誤 1130 (HY000) 相關的任何問題需要仔細的除錯和故障排除技術。您可以採取的一些步驟包括檢查防火牆設定、驗證您的登入憑據是否正確,並確保客戶端和伺服器機器共享相容的字元集和排序規則。

修復錯誤

在瞭解了錯誤 1130 (HY000) 的含義並確定了其可能的原因之後,現在該修復錯誤了。您可以執行多項操作來修復此錯誤,包括檢查 MySQL 使用者許可權、防火牆設定和 MySQL 配置檔案。

檢查 MySQL 使用者許可權

錯誤 1130 (HY000) 發生的最常見原因之一是許可權不足。要檢查 MySQL 中的許可權,請以 root 使用者身份登入並鍵入以下命令:

SHOW GRANTS FOR 'user'@'localhost'; 

此命令中的“user”指的是您要檢查許可權的使用者名稱。更改此值以匹配您的使用者。

輸出將顯示授予該特定使用者的所有許可權。如果輸出顯示沒有或許可權有限,則需要為您的使用者授予必要的許可權。

要為您的使用者授予必要的許可權,請使用此命令:

GRANT ALL PRIVILEGES ON *.* TO 'user'@'localhost'; FLUSH PRIVILEGES; 

以上程式碼授予所有資料庫和表上所有可用的許可權。將“user”替換為您所需的使用者名稱,並將 localhost 替換為您所需的主機。

檢查防火牆設定

在某些情況下,防火牆可能會阻止伺服器之間的訪問,從而導致錯誤 1130 (HY000)。因此,務必檢查是否有任何防火牆設定阻止外部客戶端訪問。

要在 Windows 系統上檢查防火牆設定,請轉到控制面板 > Windows 防火牆 > 高階設定 > 入站規則。在 Linux 系統中,使用 iptables 命令或 UFW(Uncomplicated Firewall)。

配置防火牆設定以允許 MySQL 連線

如果防火牆設定不允許 MySQL 連線,則可以將其配置為允許連線。開啟 MySQL 正在執行的埠(預設埠:3306),並允許透過該埠的流量。

檢查 MYSQL 配置檔案

MYSQL 配置檔案 (my.cnf) 包含有關伺服器執行方式的重要資訊。務必確保其中包含正確的 IP 地址和埠號。要編輯 my.cnf 檔案,請使用您喜歡的文字編輯器:

sudo nano /etc/my.cnf 

找到 bind-address 並將其值更改為“0.0.0.0”(允許所有連線)或您的本地 IP 地址(如果您只想來自本地機器的連線)。

bind-address = 0.0.0.0 

如果 MySQL 正在非標準埠號上執行,請找到包含“port”的行,並將它的值更改為您所需的值,如下所示:

port = 1234 

重新啟動 MySQL 服務

對 MYSQL 配置檔案或防火牆設定進行任何更改後,必須重新啟動 MYSQL 伺服器服務才能使更改生效。

在 Windows 和 Linux 系統上重新啟動 MySQL 服務的步驟

Windows

  • 從控制面板 > 管理工具 > 服務中選擇“服務”。

  • 從服務列表中選擇“MySQL”。

  • 從上下文選單或操作窗格中選擇“重新啟動”。

Linux

  • 執行此命令以停止 MySQL 服務:

sudo systemctl stop mysql.service 
  • 等待幾秒鐘,然後執行此命令重新啟動 MySQL 服務:

sudo systemctl start mysql.service 

以上步驟將確保您的 MYSQL 伺服器正在執行,並應用了您所做的所有更改。

預防技巧

保持良好的安全實踐

預防措施始終優於補救措施。因此,保持良好的安全實踐是確保系統安全和可靠的重要組成部分。

您可以維護良好安全實踐的方法之一是確保只有授權使用者才能訪問您的 MySQL 伺服器。您可以透過設定強密碼並僅嚮明確需要訪問的使用者授予訪問許可權來實現此目的。

此外,建議避免將 root 使用者帳戶用作標準做法,因為這可能導致重大的安全風險。維護良好安全實踐的另一個重要方法是實施強大的密碼策略,要求使用者定期設定強密碼。

定期檢查更新和補丁

MySQL 定期釋出更新和補丁,以解決已知的錯誤、最佳化效能、引入新功能或增強功能,最重要的是 - 降低其軟體中潛在的安全漏洞。因此,定期檢查更新可確保您的 MySQL 伺服器擁有針對任何已識別弱點或漏洞的最新修復程式。

使用過時的軟體或未能安裝必要的補丁會使您的系統面臨資料洩露、惡意軟體感染等網路威脅的風險。因此,確保您持續應用軟體升級不僅可以使您的 MySQL 伺服器保持最新狀態,還可以大大降低遭受潛在攻擊的風險。

結論

修復錯誤 1130 (HY000) 看起來可能是一項艱鉅的任務,但透過一些故障排除和配置調整,您可以使您的 MySQL 伺服器再次平穩執行。通過了解錯誤、檢查使用者許可權和防火牆設定、編輯 MySQL 配置檔案以及重新啟動 MySQL 服務,您將能夠解決此令人沮喪的問題。

需要注意的是,良好的安全實踐對於防止未來的錯誤和維護安全的 MySQL 環境至關重要。還建議定期檢查更新和補丁,以確保您的系統是最新的,並受到潛在漏洞的保護。

更新於: 2023 年 6 月 5 日

14K+ 閱讀量

開啟你的職業生涯

透過完成課程獲得認證

立即開始
廣告