欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL 無監(jiān)聽端口故障問題排查記錄

 更新時間:2025年07月25日 09:08:15   作者:數(shù)據(jù)與人文  
文章解析MySQL運維中因skip-grant-tables參數(shù)隱性啟用skip-networking導(dǎo)致端口未監(jiān)聽的故障,指導(dǎo)如何排查及恢復(fù)網(wǎng)絡(luò)連接,強(qiáng)調(diào)參數(shù)關(guān)聯(lián)與安全機(jī)制,本文給大家介紹MySQL 無監(jiān)聽端口故障問題排查記錄,感興趣的朋友一起看看吧

在 MySQL 運維中,"無法連接數(shù)據(jù)庫" 是常見問題,而 "無監(jiān)聽端口" 則是其中較為隱蔽的一類。本文結(jié)合實際案例,詳細(xì)拆解 MySQL 端口未監(jiān)聽的故障排查過程,揭示skip-grant-tables參數(shù)背后的隱性影響,幫助運維人員快速定位并解決類似問題。

一、故障現(xiàn)象:連接失敗與端口異常

某運維人員反饋,遠(yuǎn)程客戶端無法連接 MySQL 實例,報錯信息如下:

ERROR 2003 (HY000): Can't connect to MySQL server on '127.0.0.1' (111)

初步排查發(fā)現(xiàn)三個關(guān)鍵異常:

  • 進(jìn)程存在:MySQL 進(jìn)程正常運行(通過ps -ef | grep mysql確認(rèn)):
    [root@wx ~]# ps -ef|grep [m]ysql
    mysql 25973 1 1 8月30 ? 02:43:20 /mysqldata/mysql/base/8.0.24/bin/mysqld --defaults-file=/mysqldata/mysql/etc/3308/my.cnf --daemonize --pid-file=/mysqldata/mysql/data/3308/mysqld.pid --user=mysql --socket=/mysqldata/mysql/data/3308/mysqld.sock --port=3308
  • 端口未監(jiān)聽:檢查 3308 端口無監(jiān)聽(lsof -i:3308ss -nltp|grep 3308均無輸出)。
  • 日志與變量異常:啟動日志顯示port: 0,數(shù)據(jù)庫內(nèi)查詢port變量也返回 0:
    mysql> show variables like 'port';
    +---------------+-------+
    | Variable_name | Value |
    +---------------+-------+
    | port          | 0     |
    +---------------+-------+

二、排查過程:從常見到特殊的逐步深入

1. 排除常規(guī)原因

  • 防火墻:確認(rèn)防火墻已開放 3308 端口(firewall-cmd --list-ports顯示 3308/tcp 已開放)。
  • 配置文件:檢查my.cnf,確認(rèn)port=3308配置正確,無語法錯誤。
  • skip-networking 參數(shù):常規(guī)情況下,skip-networking會禁用 TCP/IP 連接,導(dǎo)致端口不監(jiān)聽。但檢查配置文件,未發(fā)現(xiàn)該參數(shù)。

2. 關(guān)鍵線索:skip-grant-tables的隱性影響

在排查配置文件時,發(fā)現(xiàn)啟用了skip-grant-tables參數(shù):

[mysqld]
skip-grant-tables  # 允許無密碼登錄,禁用權(quán)限檢查
port=3308
socket=/mysqldata/mysql/data/3308/mysqld.sock

通過查閱 MySQL 官方文檔,發(fā)現(xiàn)skip-grant-tables的特殊行為:
當(dāng)啟用skip-grant-tables時,MySQL 會自動啟用skip-networking,即使配置文件中未顯式設(shè)置。這是因為skip-grant-tables禁用了權(quán)限系統(tǒng)(任何人可無密碼登錄),為安全起見,MySQL 會默認(rèn)關(guān)閉網(wǎng)絡(luò)連接,僅允許通過 socket 本地連接,從而導(dǎo)致端口被強(qiáng)制設(shè)置為 0(不監(jiān)聽任何 TCP 端口)。

三、原理詳解:skip-grant-tables的安全機(jī)制

skip-grant-tables是 MySQL 的應(yīng)急參數(shù),主要用于重置丟失的 root 密碼(無需驗證權(quán)限直接登錄)。但其設(shè)計包含嚴(yán)格的安全限制:

  • 禁用權(quán)限表:MySQL 啟動時不加載mysql庫中的權(quán)限表(如userdb),所有用戶可無密碼登錄,且擁有全部權(quán)限。
  • 自動啟用skip-networking:為防止遠(yuǎn)程惡意訪問,強(qiáng)制禁用 TCP/IP 連接,僅允許通過socket文件本地連接(port=0即為此機(jī)制的體現(xiàn))。
  • 其他限制:禁用定時事件、插件加載、密碼失效機(jī)制等依賴權(quán)限表的功能。

這解釋了為何配置port=3308卻實際監(jiān)聽端口為 0——skip-grant-tables的安全機(jī)制覆蓋了顯式端口配置。

四、解決方案:恢復(fù)正常端口監(jiān)聽

1. 臨時恢復(fù)(適用于需遠(yuǎn)程操作的場景)

若需臨時啟用網(wǎng)絡(luò)連接(如遠(yuǎn)程重置密碼后驗證),可在登錄后執(zhí)行權(quán)限刷新操作,觸發(fā)權(quán)限表加載,從而自動關(guān)閉skip-networking

-- 本地通過socket登錄
mysql -S /mysqldata/mysql/data/3308/mysqld.sock
-- 刷新權(quán)限表(加載權(quán)限系統(tǒng),自動關(guān)閉skip-networking)
flush privileges;
-- 此時端口已恢復(fù)監(jiān)聽
show variables like 'port';  -- 輸出3308

2. 永久解決(推薦)

完成應(yīng)急操作后,應(yīng)立即禁用skip-grant-tables,恢復(fù)正常安全機(jī)制:

  • 編輯my.cnf,注釋或刪除skip-grant-tables
    [mysqld]
    # skip-grant-tables  # 注釋此行
    port=3308
    socket=/mysqldata/mysql/data/3308/mysqld.sock
  • 重啟 MySQL 服務(wù):
    systemctl restart mysqld  # 或?qū)?yīng)服務(wù)名
  • 驗證端口監(jiān)聽:
    ss -nltp|grep 3308  # 顯示監(jiān)聽狀態(tài)

五、總結(jié)與最佳實踐

1. skip-grant-tables使用規(guī)范

  • 僅應(yīng)急使用:僅限重置密碼等緊急場景,操作完成后立即禁用。
  • 本地操作:啟用期間僅通過socket本地連接,避免遠(yuǎn)程暴露風(fēng)險。
  • 及時刷新權(quán)限:若需臨時遠(yuǎn)程訪問,登錄后立即執(zhí)行flush privileges,并在操作后重啟服務(wù)禁用參數(shù)。

2. 端口異常排查思路

遇到端口未監(jiān)聽時,除常規(guī)檢查portskip-networking外,需特別關(guān)注:

  • 是否啟用skip-grant-tables(隱性啟用skip-networking)。
  • 啟動日志中port的實際值(是否為 0)。
  • 權(quán)限刷新后參數(shù)的動態(tài)變化(flush privileges的影響)。

通過本文案例可見,MySQL 的部分參數(shù)存在隱性關(guān)聯(lián)(如skip-grant-tablesskip-networking),運維中需深入理解參數(shù)原理,而非僅依賴表面配置。遇到異常時,結(jié)合官方文檔與日志信息,往往能快速定位根因。

到此這篇關(guān)于MySQL 無監(jiān)聽端口故障 的文章就介紹到這了,更多相關(guān)mysql無監(jiān)聽端口內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • MySQL?優(yōu)化利器?SHOW?PROFILE?的實現(xiàn)原理及細(xì)節(jié)展示

    MySQL?優(yōu)化利器?SHOW?PROFILE?的實現(xiàn)原理及細(xì)節(jié)展示

    這篇文章主要介紹了MySQL優(yōu)化利器SHOW?PROFILE的實現(xiàn)原理,通過實例代碼展示SHOW PROFILE的用法,需要的朋友可以參考下
    2024-12-12
  • 淺談Mysql多表連接查詢的執(zhí)行細(xì)節(jié)

    淺談Mysql多表連接查詢的執(zhí)行細(xì)節(jié)

    這篇文章主要介紹了淺談Mysql多表連接查詢的執(zhí)行細(xì)節(jié),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • 安裝rpm包時提示錯誤:依賴檢測失敗的解決方法

    安裝rpm包時提示錯誤:依賴檢測失敗的解決方法

    今天在虛擬機(jī)中裝MySQL的時候,突然出現(xiàn)了這個依賴檢測錯誤,下面這篇文章主要給大家介紹了關(guān)于安裝rpm包時提示錯誤:依賴檢測失敗的解決方法,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-09-09
  • MySQL server has gone away錯誤提示解決方法

    MySQL server has gone away錯誤提示解決方法

    今天遇到類似的情景,MySQL只是冷冷的說:MySQL server has gone away。
    2008-11-11
  • mysql錯誤處理之ERROR 1786 (HY000)

    mysql錯誤處理之ERROR 1786 (HY000)

    最近一直在mysql的各個版本直接徘徊,這中間遇到了各種各樣的錯誤,將已經(jīng)處理完畢的幾個錯誤整理了一下,分享給大家,首先我們來看看錯誤提示 ERROR 1786 (HY000)
    2014-07-07
  • MySQL數(shù)據(jù)庫中case表達(dá)式的用法示例

    MySQL數(shù)據(jù)庫中case表達(dá)式的用法示例

    這篇文章主要介紹了MySQL數(shù)據(jù)庫中case表達(dá)式用法的相關(guān)資料,MySQL的CASE表達(dá)式用于條件判斷,返回不同結(jié)果,適用于SELECT、UPDATE和ORDERBY,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2025-02-02
  • 詳解MySQL中的數(shù)據(jù)類型和schema優(yōu)化

    詳解MySQL中的數(shù)據(jù)類型和schema優(yōu)化

    這篇文章主要介紹了MySQL中的數(shù)據(jù)類型和schema優(yōu)化的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)MySQL的知識,感興趣的朋友可以了解下
    2020-10-10
  • 一篇文章帶你了解MySQL索引下推

    一篇文章帶你了解MySQL索引下推

    索引條件下推,也叫索引下推,英文全稱Index?Condition?Pushdown,簡稱ICP,索引下推是MySQL5.6新添加的特性,用于優(yōu)化數(shù)據(jù)的查詢,下面這篇文章主要給大家介紹了關(guān)于MySQL索引下推的相關(guān)資料,需要的朋友可以參考下
    2022-10-10
  • sqlmap注入圖文詳解

    sqlmap注入圖文詳解

    sqlmap 是一個自動SQL 射入工具。本文收集了一些利用Sqlmap做注入測試的TIPS,其中也包含一點繞WAF的技巧,便于大家集中查閱,希望能給你帶來幫助
    2021-08-08
  • MySQL中data_sub()函數(shù)定義和用法

    MySQL中data_sub()函數(shù)定義和用法

    使用 date_sub() 函數(shù),從 answer_date 減去相應(yīng)的天數(shù),這個天數(shù)是由上面計算的行號決定,也就是減去行號,從而來生成一個新的日期,這篇文章主要介紹了MySQL中data_sub()函數(shù),需要的朋友可以參考下
    2024-02-02

最新評論