关于MySQL的二进制日志(binlog),我们都知道二进制日志(binlog)非常重要,尤其当你需要point to point灾难恢复的时侯,所以我们要对其进行备份。关于二进制日志(binlog)的备份,可以基于flush logs方式先切换binlog,然后拷贝&压缩到到远程服务器或本地服务器的其他存储上,例如挂载的NAS存储,也可以使用mysqlbinlog实现binlog的备份,可以实现MySQL二进制日志(binlog)的本地备份或远程备份。最终将MySQL二进制日志(binlog)备份文件存储到磁带上。各个公司的备份策略或备份工具有所不同,这里不做展开,我们主要考虑MySQL二进制日志(binlog)备份方案/策略尽可能尽善尽美,在一些极端情况下少丢失数据。例如,第一种方式,这种备份方式都是周期性的,如果在某个周期中,遇到一些极端情况,例如服务器宕机了,硬盘损坏了,就可能导致这段时间的binlog丢失了。而且这个周期时间太长,二进制日志(binlog)丢失的风险就越大,如果这个周期太短,频繁切换binlog也不好。所以还是使用mysqlbinlog来备份二进制日志(binlog),这里主要介绍一下我写的MySQL二进制日志的备份脚本,这个脚本参考了如何远程备份MySQL binlog[1]中的脚本,但是在其基础上做了很多改进和完善:
参考资料中的脚本由于使用了循环操作,不适合在作业中调用。一般需要手工执行脚本,让其在后台运行。遇到服务器重启或其他异常情况,此脚本可能出现未能执行的情况。
增加了mysql_binlog_backup_job.sh脚本,作业会定期调用此脚本,此脚本会判断mysqlbinlog是否还在执行二进制日志备份。即使遇到了数据库服务器重启等情况,备份MySQL的二进制日志(binlog)也不会成为问题。
不用手工指定第一个binlog文件参数,采用从数据库读取binlog的值.如果是在本地服务器执行binlog的备份,还可以从二进制日志索引文件中获取(参考脚本注释部分)
使用mysql_config_editor配置账号密码,避免在脚本中使用数据库用户的明文密码。
邮件告警处理。
在使用脚本前,必须配置mailx,创建数据库连接账号
create user bkuser@'xxx.xxx.xxx.xxx' identified by "******"; grant replication client on *.* to bkuser@'%'; grant replication slave on *.* to bkuser@'%';
这个根据实际情况调整,例如我就是使用Xtrabackup的账号来备份MySQL的binlog。 另外,如果在MySQL数据库服务器本机备份binlog,那么就在本机安全加密登录,如果是在远程服务器备份binlog的话,就在远程服务器配置
$ mysql_config_editor set --login-path=server1_dbbackup -h xxx.xxx.xxx.xxx -ubkuser -p -P 3306 Enter password:
mysql_binlog_backup_job.sh脚本
#!/bin/sh ######################################################################################### # # # This script is used for mysql binlog backup. # # # # ####################################################################################### # # # ScriptName : mysql_binlog_backup_job.sh # # Author : 潇湘隐者 # # CerateDate : 2017-04-14 # # Description : # #---------------------------------------------------------------------------------------# # 作业中调用此脚本,然后此脚本去调用mysql_binlog_backup.sh执行 # # MySQL的二进制日志备份(将MySQL的二进制日志备份到NAS存储或备份存# # 储上),此脚本还会判断mysqlbinlog是否在一直在备份二进制日志, # # 如果是的话,则退出当前脚本。如果mysqlbinlog已经由于服务器重 # # 启等原因退出了,则会重新调用mysql_binlog_backup.sh # #***************************************************************************************# # Version Modified Date Description # #***************************************************************************************# # V.1.0 2016-06-20 create the script for mysql binlog backp # # V.1.1 2016-07-26 fix some bug # # V.1.2 2023-04-14 $FIRST_BINLOG从MySQL中获取,即使远程备份也不用手工 # # 设定,本地备份也可以这种方式,本地备份默认从 # # mysql binlog index file读取 # ######################################################################################### #mysql binlog备份文件的保留天数 KEEPY_DAYS=7 FIRST_BINLOG='' LOG_DATE=$(date +%Y_%m_%d_%H_%M_%S) BACKUP_DATE=$(date +%Y_%m_%d_%H_%M_%S) LOCAL_BACKUP_DIR=/dbbackup/mysql_backup/db_backup/binlog_backup #MYSQL_BINLOG_INDEX=/data/bin_logs/mysql_binlog.index MYSQL_CMD=/opt/mysql/mysql8.0/bin/mysql BACKUP_LOG_PATH=/dbbackup/mysql_backup/logs ERROR_LOG=${BACKUP_LOG_PATH}/binlog_backup_error_${BACKUP_DATE}.log FILE_TYPE="mysql_binlog.*" SQL_TEXT='show binary logs' MAIL_TO="xxxx@xxx.com.cn" MAIL_FROM="xxxx@xxx.com.cn" MYSQL_LOGIN_PATH=server1_dbbackup error() { echo "$1" 1>&2 echo "$1" >> ${ERROR_LOG} echo "$1" | mailx -s "The binlog backup on the server `hostname` failed ,please check the log!" -r ${MAIL_FROM} ${MAIL_TO} exit 1 } ##目录不存在则创建目录 if [ ! -d $BACKUP_LOG_PATH ];then mkdir -p $BACKUP_LOG_PATH fi if [ ! -x /bin/mailx ];then error "{LOG_DATE}:mailx did not exists!" fi if [ ! -x $MYSQL_CMD ];then error "{LOG_DATE}: mysql client did not exists!" fi #SQL_RESULT=`mysql -h${REMOTE_HOST} -P${PORT} -u${USER_NAME} -p${PASSWORD} ${DATABASE_NAME} -Bse "${SQL_TEXT}"` SQL_RESULT=`$MYSQL_CMD --login-path=${MYSQL_LOGIN_PATH} -Bse "${SQL_TEXT}"` FIRST_BINLOG=`echo ${SQL_RESULT} | awk '{print $1}'` echo $FIRST_BINLOG if [ ! $FIRST_BINLOG ];then error "${LOG_DATE}: please check the mysql binlog" fi ##create local_backup_dir if this folder is not exists if [ ! -d ${LOCAL_BACKUP_DIR} ];then mkdir -p ${LOCAL_BACKUP_DIR} fi if [ ! -e ${MYSQL_BINLOG_INDEX} ];then error "${LOG_DATE}:mysql binlog index file did not exists, please check it!" fi #删除KEEPY_DAYS天之前的binlog备份文件 find ${LOCAL_BACKUP_DIR} -name "${FILE_TYPE}" -type f -mtime +$KEEPY_DAYS -delete #删除30天前的错误日志 find ${BACKUP_LOG_PATH} -name "binlog_backup_error*.log" -mtime 30 -delete process_num=$(ps -ef | grep -w mysqlbinlog | grep -v grep |wc -l) if [ ${process_num} -ge 1 ];then exit 1 else #如果是在本机备份binlog到NAS存储或备份存储上,从二进制文件的索引获取当前MySQL数据库最小的binlog文件 #如果是远程备份二进制日志(binlog)的话,则使用下面注释的脚本获取 #FIRST_BINLOG=$(head -1 ${MYSQL_BINLOG_INDEX}) #FIRST_BINLOG=$(find ${LOCAL_BACKUP_DIR} -name "mysql_binlog.*" -printf "%p\t%C@\n" | sort -k2 -g |head -1 | awk '{print $1}' | awk -F "/" '{print $NF}') echo ${FIRST_BINLOG} nohup sh /dbbackup/mysql_backup/scripts/mysql_binlog_backup.sh ${FIRST_BINLOG} ${LOCAL_BACKUP_DIR} ${FILE_TYPE} & fi
mysql_binlog_backup.sh脚本
#!/bin/sh ######################################################################################### # # # This script is used for mysql binlog local or remote backup. # # # # ####################################################################################### # # # ScriptName : mysql_binlog_backup.sh # # Author : Kerry # # CerateDate : 2017-04-14 # # Description : # #---------------------------------------------------------------------------------------# # 此脚本参考了https://www.cnblogs.com/ivictor/p/5502240.html # # 的脚本,在它的基础上做了一些改进,例如,ivitcor中脚本备份binlog# # 如果服务器重启了,则必须手动执行脚本....... # #***************************************************************************************# # Version Modified Date Description # #***************************************************************************************# # V.1.0 2016-06-20 create the script for mysql binlog backp # # V.1.1 2016-07-26 fix some bug # ######################################################################################### BACKUP_BIN=/opt/mysql/mysql8.0/bin/mysqlbinlog BACKUP_LOG_PATH=/dbbackup/mysql_backup/logs LOG_DATE=$(date +%Y_%m_%d_%H_%M_%S) BACKUP_LOG=${BACKUP_LOG_PATH}/binlog_backup.log ERROR_LOG=${BACKUP_LOG_PATH}/binlog_backup_error_${LOG_DATE}.log #复制二进制日志的主机,可以远程MySQL数据库也可以是本机 MYSQL_LOGIN_PATH=server1_dbbackup #time to wait before reconnecting after failure SLEEP_SECONDS=10 MAIL_TO="xxx@xxx.com.cn" MAIL_FROM="xxx@xxx.com.cn" error() { echo "$1" 1>&2 echo "$1" >> ${ERROR_LOG} echo "$1" | mailx -s "The binlog backup on the server `hostname` failed ,please check the log!" -r ${MAIL_FROM} ${MAIL_TO} exit 1 } ##目录不存在则创建目录 if [ ! -d $BACKUP_LOG_PATH ];then mkdir -p $BACKUP_LOG_PATH fi if [ "$#" -ne 3];then error "${LOG_DATE}:you must input 3 arguments" fi if [ ! $1 ];then error "${LOG_DATE}:first_binlog arguments is null" else FIRST_BINLOG=$1 fi if [ ! $2 ];then error "${LOG_DATE}:local_backup_dir arguments is null" else LOCAL_BACKUP_DIR=$2 fi if [ ! $3 ];then error "${LOG_DATE}:file_type arguments is null" else FILE_TYPE=$3 fi ##检查mysqlbinlog二进制文件是否存在 if [ ! -x ${BACKUP_BIN} ];then error "${LOG_DATE}:mysqlbinlog did not exists, please check it!" fi cd ${LOCAL_BACKUP_DIR} ## 运行while循环,连接断开后等待指定时间,重新连接 while : do #如果当前备份二进制日志目录为空,则使用MySQL实例最小的二进制日志文件名 if [ `ls -A "${LOCAL_BACKUP_DIR}" |wc -l` -eq 0 ];then LAST_BINLOG_FILE=${FIRST_BINLOG} else #LAST_FILE=`ls -l ${LOCAL_BACKUP_DIR} | grep -v backuplog |tail -n 1 |awk '{print $9}'` #echo ${LOCAL_BACKUP_DIR} #echo ${FILE_TYPE} #取mysqlbinlog备份的最后一个binlog文件名 LAST_BINLOG_FILE=`find ${LOCAL_BACKUP_DIR} -name "${FILE_TYPE}" -printf "%p\t%C@\n" | sort -k2 -g |tail -1 | awk '{print $1}' | awk -F "/" '{print $NF}'` fi #${BACKUP_BIN} --login-path=${MYSQL_LOGIN_PATH} --read-from-remote-server --raw --stop-never --host=${REMOTE_HOST} --port=${REMOTE_PORT} ${LAST_BINLOG_FILE} ${BACKUP_BIN} --login-path=${MYSQL_LOGIN_PATH} --read-from-remote-server --raw --stop-never ${LAST_BINLOG_FILE} echo "`date +"%Y/%m/%d %H:%M:%S"` mysqlbinlog停止,返回代码:$?" | tee -a ${BACKUP_LOG} echo "${SLEEP_SECONDS}秒后再次连接并继续备份" | tee -a ${BACKUP_LOG} sleep ${SLEEP_SECONDS} done
配置作业
*/10 * * * * /dbbackup/mysql_backup/scripts/mysql_binlog_backup_job.sh >> /dbbackup/mysql_backup/logs/mysql_binlog_back.log 2>&1
以上是MySQL中binlog怎麼備份腳本的詳細內容。更多資訊請關注PHP中文網其他相關文章!

MySQL索引基数对查询性能有显著影响:1.高基数索引能更有效地缩小数据范围,提高查询效率;2.低基数索引可能导致全表扫描,降低查询性能;3.在联合索引中,应将高基数列放在前面以优化查询。

MySQL學習路徑包括基礎知識、核心概念、使用示例和優化技巧。 1)了解表、行、列、SQL查詢等基礎概念。 2)學習MySQL的定義、工作原理和優勢。 3)掌握基本CRUD操作和高級用法,如索引和存儲過程。 4)熟悉常見錯誤調試和性能優化建議,如合理使用索引和優化查詢。通過這些步驟,你將全面掌握MySQL的使用和優化。

MySQL在現實世界的應用包括基礎數據庫設計和復雜查詢優化。 1)基本用法:用於存儲和管理用戶數據,如插入、查詢、更新和刪除用戶信息。 2)高級用法:處理複雜業務邏輯,如電子商務平台的訂單和庫存管理。 3)性能優化:通過合理使用索引、分區表和查詢緩存來提升性能。

MySQL中的SQL命令可以分為DDL、DML、DQL、DCL等類別,用於創建、修改、刪除數據庫和表,插入、更新、刪除數據,以及執行複雜的查詢操作。 1.基本用法包括CREATETABLE創建表、INSERTINTO插入數據和SELECT查詢數據。 2.高級用法涉及JOIN進行表聯接、子查詢和GROUPBY進行數據聚合。 3.常見錯誤如語法錯誤、數據類型不匹配和權限問題可以通過語法檢查、數據類型轉換和權限管理來調試。 4.性能優化建議包括使用索引、避免全表掃描、優化JOIN操作和使用事務來保證數據一致性

InnoDB通過undolog實現原子性,通過鎖機制和MVCC實現一致性和隔離性,通過redolog實現持久性。 1)原子性:使用undolog記錄原始數據,確保事務可回滾。 2)一致性:通過行級鎖和MVCC確保數據一致。 3)隔離性:支持多種隔離級別,默認使用REPEATABLEREAD。 4)持久性:使用redolog記錄修改,確保數據持久保存。

MySQL在數據庫和編程中的地位非常重要,它是一個開源的關係型數據庫管理系統,廣泛應用於各種應用場景。 1)MySQL提供高效的數據存儲、組織和檢索功能,支持Web、移動和企業級系統。 2)它使用客戶端-服務器架構,支持多種存儲引擎和索引優化。 3)基本用法包括創建表和插入數據,高級用法涉及多表JOIN和復雜查詢。 4)常見問題如SQL語法錯誤和性能問題可以通過EXPLAIN命令和慢查詢日誌調試。 5)性能優化方法包括合理使用索引、優化查詢和使用緩存,最佳實踐包括使用事務和PreparedStatemen

MySQL適合小型和大型企業。 1)小型企業可使用MySQL進行基本數據管理,如存儲客戶信息。 2)大型企業可利用MySQL處理海量數據和復雜業務邏輯,優化查詢性能和事務處理。

InnoDB通過Next-KeyLocking機制有效防止幻讀。 1)Next-KeyLocking結合行鎖和間隙鎖,鎖定記錄及其間隙,防止新記錄插入。 2)在實際應用中,通過優化查詢和調整隔離級別,可以減少鎖競爭,提高並發性能。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境