MySQL5.7限制general_log日志大小的實(shí)現(xiàn)
背景
需求:
- 在MySQL 5.7.41中開啟
general_log
并限制其大小,避免快速增長占用硬盤空間。
解決:
- 通過定時(shí)任務(wù),執(zhí)行簡單的腳本,判斷
general_log
日志的大小,實(shí)現(xiàn)對(duì)通用查詢?nèi)罩镜?ldquo;每日備份”或“每日清理”的功能。
多說幾句:
- 等保二級(jí)要求必須開啟MySQL數(shù)據(jù)庫的通用查詢?nèi)罩?code>general_log ,但其文件大小增長速度太快,數(shù)據(jù)庫有效數(shù)據(jù)都還沒增長多少,硬盤空間可能就會(huì)被
general_log
日志占用不少。而binog
至少還能通過binlog_expire_logs_seconds
過期時(shí)間參數(shù)設(shè)置日志保存策略,避免占用空間。沒有這樣的參數(shù)限制general_log
,必然要通過其它手段限制general_log
空間。
實(shí)際操作:備份腳本和清理腳本
提供兩種思路:
- 思路一:每日檢查日志大小,當(dāng)其超過某個(gè)閾值時(shí),將文件復(fù)制歸檔到某個(gè)專門存儲(chǔ)日志的目錄。
- 思路二:每日檢查日志大小,當(dāng)超過某個(gè)閾值時(shí),不執(zhí)行歸檔備份,直接將
general_log
內(nèi)容清除。
MySQL中開啟general日志需要修改my.cnf文件,增加以下兩行指定日志存儲(chǔ)路徑:
[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
快速驗(yàn)證腳本的方法:dd創(chuàng)建日志文件
- 用dd命令快速生成指定大小的文件,比如生成101MB大小的
/mnt/general.log
文件,可以執(zhí)行以下命令:
dd if=/dev/zero of=/mnt/general.log bs=1M count=101
- 執(zhí)行之前準(zhǔn)備的腳本文件,查看結(jié)果。
參考截圖
實(shí)際操作:配置corntab定時(shí)任務(wù)
給腳本配置可執(zhí)行權(quán)限:
chmod +x bak_general_log.sh chmod +x clear_general_log.sh
使用cron等工具將腳本定期執(zhí)行,例如每天凌晨執(zhí)行一次:
crontab -e
然后在編輯器中添加以下內(nèi)容:
0 0 * * * /mnt/bak_general_log.sh 0 0 * * * /mnt/clear_general_log.sh
上述腳本二選一即可。
結(jié)束
注意:
- 備份腳本中沒有指定備份目錄。
- 備份腳本中涉及了MySQL應(yīng)用重啟。
- 備份腳本的具體內(nèi)容可根據(jù)實(shí)際情況修改。
到此這篇關(guān)于MySQL5.7限制general_log日志大小的文章就介紹到這了,更多相關(guān)MySQL5.7限制general_log日志內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MySQL9.0的兩種部署模式及各個(gè)版本發(fā)布的新功能
本文主要介紹了MySQL9.0的兩種部署模式及各個(gè)版本發(fā)布的新功能,文中通過圖文示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-08-08MySQL 配置文件 my.cnf / my.ini 區(qū)別解析
充分理解 MySQL 配置文件中各個(gè)變量的意義對(duì)我們有針對(duì)性的優(yōu)化 MySQL 數(shù)據(jù)庫性能有非常大的意義,這篇文章主要介紹了MySQL 配置文件 my.cnf / my.ini 區(qū)別,需要的朋友可以參考下2022-11-11MySQL中必須了解的13個(gè)關(guān)鍵字總結(jié)
這篇文章主要為大家詳細(xì)介紹了MySQL中必須了解學(xué)會(huì)的13個(gè)關(guān)鍵字,文中的示例代碼簡潔易懂,對(duì)我們掌握MySQL有一定的幫助,需要的可以了解下2023-09-09關(guān)于TIMESTAMP with implicit DEFAULT value&
本文介紹了“TIMESTAMP with implicit DEFAULT value is deprecated”錯(cuò)誤的原因及解決方法,解決方法包括顯式指定默認(rèn)值、修改字段類型、更新數(shù)據(jù)庫版本或?qū)で髱椭?感興趣的朋友一起看看吧2025-02-02MySQL數(shù)據(jù)庫主從復(fù)制與讀寫分離
大家好,本篇文章主要講的是MySQL數(shù)據(jù)庫主從復(fù)制與讀寫分離,感興趣的同學(xué)趕快來看一看吧,對(duì)你有幫助的話記得收藏一下,方便下次瀏覽2021-12-12Mysql數(shù)據(jù)庫亂碼問題的對(duì)應(yīng)方式
今天小編就為大家分享一篇關(guān)于Mysql數(shù)據(jù)庫亂碼問題的對(duì)應(yīng)方式,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2018-12-12MySQL 統(tǒng)計(jì)查詢實(shí)現(xiàn)代碼
MySQL 統(tǒng)計(jì)查詢其實(shí)就是通過SELECT COUNT() FROM 語法用于從數(shù)據(jù)表中統(tǒng)計(jì)數(shù)據(jù)行數(shù)2014-05-05利用JuiceFS使MySQL?備份驗(yàn)證性能提升?10?倍
這篇文章主要介紹了如何讓?MySQL?備份驗(yàn)證性能提升?10?倍,JuiceFS?非常適合用來做?MySQL?物理備份,通過不斷調(diào)整?XtraBackup?的參數(shù)和?JuiceFS?的掛載參數(shù),在一個(gè)小時(shí)內(nèi)將時(shí)間縮短到原先的?1/10,下文一起來看相關(guān)內(nèi)容的詳細(xì)介紹吧2022-03-03