MySQL 8.0 重新定義了錯誤日誌輸出和過濾,改善了原來臃腫並且可讀性很差的錯誤日誌。比如增加了 JSON 輸出,在原來的日誌後面以序號以及 JSON 字尾的方式展示。比如我機器上的 MySQL 以 JSON 儲存的錯誤日誌 mysqld.log.00.json:
以 JSON 輸出錯誤日誌後可讀性和可操作性增強了許多。這裡可以用 Linux 命令 jq 或者把這個字串 COPY 到其他解析 JSON 的工具方便處理。只想非常快速的拿出錯誤資訊,忽略其他資訊。
使用 JSON 輸出的前提是安裝 JSON 輸出部件。
格式為:過濾規則;日誌輸出;[過濾規則]日誌輸出;檢視安裝好的部件
現在設定 JSON 輸出,輸出到系統日誌的同時輸出到 JSON 格式日誌。
來測試一把。我之前已經把表 a 物理檔案刪掉了。
現在錯誤日誌裡有 5 條記錄。
JSON 日誌裡也有 5 條記錄。
那可能有人就問了,這有啥意義呢?只是把格式變了,過濾的規則我看還是沒變。那我們現在給第二條日誌輸出加過濾規則先把過濾日誌的部件安裝起來
只保留 error,其餘的一律過濾掉。
檢索一張誤刪的表
檢視錯誤日誌和 JSON 錯誤日誌發現錯誤日誌裡有一條 Warning,JSON 錯誤日誌裡的被過濾掉了。
再舉個例子,每 60 秒只允許記錄一個 Warning 事件
多次執行
現在錯誤日誌裡有三條 warning 資訊
mysqld.log.00.json 只有一條
總結,我這裡簡單介紹了下 MySQL 8.0 的錯誤日誌過濾以及 JSON 輸出。MySQL 8.0 的component_log_filter_dragnet 部件過濾規則非常靈活,可以參考手冊,根據它提供的語法寫出自己的過濾掉的日誌輸出。
MySQL 8.0 重新定義了錯誤日誌輸出和過濾,改善了原來臃腫並且可讀性很差的錯誤日誌。比如增加了 JSON 輸出,在原來的日誌後面以序號以及 JSON 字尾的方式展示。比如我機器上的 MySQL 以 JSON 儲存的錯誤日誌 mysqld.log.00.json:
以 JSON 輸出錯誤日誌後可讀性和可操作性增強了許多。這裡可以用 Linux 命令 jq 或者把這個字串 COPY 到其他解析 JSON 的工具方便處理。只想非常快速的拿出錯誤資訊,忽略其他資訊。
使用 JSON 輸出的前提是安裝 JSON 輸出部件。
格式為:過濾規則;日誌輸出;[過濾規則]日誌輸出;檢視安裝好的部件
現在設定 JSON 輸出,輸出到系統日誌的同時輸出到 JSON 格式日誌。
來測試一把。我之前已經把表 a 物理檔案刪掉了。
現在錯誤日誌裡有 5 條記錄。
JSON 日誌裡也有 5 條記錄。
那可能有人就問了,這有啥意義呢?只是把格式變了,過濾的規則我看還是沒變。那我們現在給第二條日誌輸出加過濾規則先把過濾日誌的部件安裝起來
只保留 error,其餘的一律過濾掉。
檢索一張誤刪的表
檢視錯誤日誌和 JSON 錯誤日誌發現錯誤日誌裡有一條 Warning,JSON 錯誤日誌裡的被過濾掉了。
再舉個例子,每 60 秒只允許記錄一個 Warning 事件
多次執行
現在錯誤日誌裡有三條 warning 資訊
mysqld.log.00.json 只有一條
總結,我這裡簡單介紹了下 MySQL 8.0 的錯誤日誌過濾以及 JSON 輸出。MySQL 8.0 的component_log_filter_dragnet 部件過濾規則非常靈活,可以參考手冊,根據它提供的語法寫出自己的過濾掉的日誌輸出。