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

MySQL5.7限制general_log日志大小的實現

 更新時間:2024年10月29日 11:28:59   作者:高達可以過山車不行  
MySQL5.7.41中為避免通用查詢日志general_log快速增長占用硬盤空間,可以通過定時任務執(zhí)行腳本進行每日備份或清理,從而限制其大小,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

背景

需求:

  • 在MySQL 5.7.41中開啟general_log 并限制其大小,避免快速增長占用硬盤空間。

解決:

  • 通過定時任務,執(zhí)行簡單的腳本,判斷general_log 日志的大小,實現對通用查詢日志的“每日備份”或“每日清理”的功能。

多說幾句:

  • 等保二級要求必須開啟MySQL數據庫的通用查詢日志general_log ,但其文件大小增長速度太快,數據庫有效數據都還沒增長多少,硬盤空間可能就會被general_log 日志占用不少。而binog 至少還能通過binlog_expire_logs_seconds過期時間參數設置日志保存策略,避免占用空間。沒有這樣的參數限制general_log,必然要通過其它手段限制general_log空間。

實際操作:備份腳本和清理腳本

提供兩種思路:

  • 思路一:每日檢查日志大小,當其超過某個閾值時,將文件復制歸檔到某個專門存儲日志的目錄。
  • 思路二:每日檢查日志大小,當超過某個閾值時,不執(zhí)行歸檔備份,直接將general_log內容清除。

MySQL中開啟general日志需要修改my.cnf文件,增加以下兩行指定日志存儲路徑:

[mysqld]
general_log = 1
general_log_file = /mnt/general.log

思路一:每日備份日志

參考腳本 bak_general_log.sh

#!/bin/bash

LOG_FILE="/mnt/general.log"
MAX_SIZE=100

if [ -f "$LOG_FILE" ]; then
    CURRENT_SIZE=$(du -m "$LOG_FILE" | awk '{print $1}')
    
    if [ "$CURRENT_SIZE" -gt "$MAX_SIZE" ]; then
        mv "$LOG_FILE" "$LOG_FILE.$(date +%Y%m%d%H%M%S)"
        touch "$LOG_FILE"
        chmod 0640 "$LOG_FILE"
        chown mysql:mysql "$LOG_FILE"
        systemctl restart mysql
    fi
fi

思路二:每日清空日志

參考腳本 clear_general_log.sh

#!/bin/bash

LOG_FILE="/mnt/general.log"
MAX_SIZE=100

if [ -f "$LOG_FILE" ]; then
    CURRENT_SIZE=$(du -m "$LOG_FILE" | awk '{print $1}')
    
    if [ "$CURRENT_SIZE" -gt "$MAX_SIZE" ]; then
        echo > "$LOG_FILE"
    fi
fi

快速驗證腳本的方法:dd創(chuàng)建日志文件

  • 用dd命令快速生成指定大小的文件,比如生成101MB大小的/mnt/general.log文件,可以執(zhí)行以下命令:
dd if=/dev/zero of=/mnt/general.log bs=1M count=101
  • 執(zhí)行之前準備的腳本文件,查看結果。

參考截圖

在這里插入圖片描述

實際操作:配置corntab定時任務

給腳本配置可執(zhí)行權限:

chmod +x bak_general_log.sh
chmod +x clear_general_log.sh

使用cron等工具將腳本定期執(zhí)行,例如每天凌晨執(zhí)行一次:

crontab -e

然后在編輯器中添加以下內容:

0 0 * * * /mnt/bak_general_log.sh
0 0 * * * /mnt/clear_general_log.sh

上述腳本二選一即可。

結束

注意:

  • 備份腳本中沒有指定備份目錄。
  • 備份腳本中涉及了MySQL應用重啟。
  • 備份腳本的具體內容可根據實際情況修改。

到此這篇關于MySQL5.7限制general_log日志大小的文章就介紹到這了,更多相關MySQL5.7限制general_log日志內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家! 

相關文章

  • MySQL9.0的兩種部署模式及各個版本發(fā)布的新功能

    MySQL9.0的兩種部署模式及各個版本發(fā)布的新功能

    本文主要介紹了MySQL9.0的兩種部署模式及各個版本發(fā)布的新功能,文中通過圖文示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2024-08-08
  • MySQL 配置文件 my.cnf / my.ini 區(qū)別解析

    MySQL 配置文件 my.cnf / my.ini 區(qū)別解析

    充分理解 MySQL 配置文件中各個變量的意義對我們有針對性的優(yōu)化 MySQL 數據庫性能有非常大的意義,這篇文章主要介紹了MySQL 配置文件 my.cnf / my.ini 區(qū)別,需要的朋友可以參考下
    2022-11-11
  • MySQL中必須了解的13個關鍵字總結

    MySQL中必須了解的13個關鍵字總結

    這篇文章主要為大家詳細介紹了MySQL中必須了解學會的13個關鍵字,文中的示例代碼簡潔易懂,對我們掌握MySQL有一定的幫助,需要的可以了解下
    2023-09-09
  • 關于TIMESTAMP with implicit DEFAULT value is deprecated 錯誤解決方法

    關于TIMESTAMP with implicit DEFAULT value&

    本文介紹了“TIMESTAMP with implicit DEFAULT value is deprecated”錯誤的原因及解決方法,解決方法包括顯式指定默認值、修改字段類型、更新數據庫版本或尋求幫助,感興趣的朋友一起看看吧
    2025-02-02
  • MySQL數據庫主從復制與讀寫分離

    MySQL數據庫主從復制與讀寫分離

    大家好,本篇文章主要講的是MySQL數據庫主從復制與讀寫分離,感興趣的同學趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽
    2021-12-12
  • 一個字段同時滿足多個條件的查詢

    一個字段同時滿足多個條件的查詢

    當一個字段需要同時等于多個值的時候,用and直接連不會有數據查出。
    2011-08-08
  • Mysql數據庫亂碼問題的對應方式

    Mysql數據庫亂碼問題的對應方式

    今天小編就為大家分享一篇關于Mysql數據庫亂碼問題的對應方式,小編覺得內容挺不錯的,現在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2018-12-12
  • MySQL 統(tǒng)計查詢實現代碼

    MySQL 統(tǒng)計查詢實現代碼

    MySQL 統(tǒng)計查詢其實就是通過SELECT COUNT() FROM 語法用于從數據表中統(tǒng)計數據行數
    2014-05-05
  • 一文了解MySQL事務隔離級別

    一文了解MySQL事務隔離級別

    這篇文章主要介紹了一文了解MySQL事務隔離級別,MySQL?事務隔離級別是為了解決并發(fā)事務互相干擾的問題的,文章介紹?4?種事物隔離,需要的小伙伴可以學習一下
    2022-07-07
  • 利用JuiceFS使MySQL?備份驗證性能提升?10?倍

    利用JuiceFS使MySQL?備份驗證性能提升?10?倍

    這篇文章主要介紹了如何讓?MySQL?備份驗證性能提升?10?倍,JuiceFS?非常適合用來做?MySQL?物理備份,通過不斷調整?XtraBackup?的參數和?JuiceFS?的掛載參數,在一個小時內將時間縮短到原先的?1/10,下文一起來看相關內容的詳細介紹吧
    2022-03-03

最新評論