MySQL中binlog怎么备份脚本

关于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 3306Enter 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=7FIRST_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.indexMYSQL_CMD=/opt/mysql/mysql8.0/bin/mysqlBACKUP_LOG_PATH=/dbbackup/mysql_backup/logsERROR_LOG=${BACKUP_LOG_PATH}/binlog_backup_error_${BACKUP_DATE}.logFILE_TYPE="mysql_binlog.*"SQL_TEXT='show binary logs'MAIL_TO="xxxx@xxx.com.cn"MAIL_FROM="xxxx@xxx.com.cn"MYSQL_LOGIN_PATH=server1_dbbackuperror(){ 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_PATHfiif [ ! -x /bin/mailx ];then    error "{LOG_DATE}:mailx did not exists!" fiif [ ! -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_BINLOGif [ ! $FIRST_BINLOG ];then   error "${LOG_DATE}: please check the mysql binlog"  fi##create local_backup_dir if this folder is not existsif [ ! -d ${LOCAL_BACKUP_DIR} ];then  mkdir -p ${LOCAL_BACKUP_DIR}fiif [ ! -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 -deleteprocess_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/mysqlbinlogBACKUP_LOG_PATH=/dbbackup/mysql_backup/logsLOG_DATE=$(date +%Y_%m_%d_%H_%M_%S)BACKUP_LOG=${BACKUP_LOG_PATH}/binlog_backup.logERROR_LOG=${BACKUP_LOG_PATH}/binlog_backup_error_${LOG_DATE}.log#复制二进制日志的主机,可以远程MySQL数据库也可以是本机MYSQL_LOGIN_PATH=server1_dbbackup#time to wait before reconnecting after failureSLEEP_SECONDS=10MAIL_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_PATHfiif [ "$#" -ne 3];then       error "${LOG_DATE}:you must input 3 arguments" fiif [ ! $1 ];then    error "${LOG_DATE}:first_binlog arguments is null" else    FIRST_BINLOG=$1fiif [ ! $2 ];then    error "${LOG_DATE}:local_backup_dir arguments is null" else    LOCAL_BACKUP_DIR=$2fiif [ ! $3 ];then    error "${LOG_DATE}:file_type arguments is null" else    FILE_TYPE=$3fi##检查mysqlbinlog二进制文件是否存在if [ ! -x ${BACKUP_BIN} ];then       error "${LOG_DATE}:mysqlbinlog did not exists, please check it!" ficd ${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怎么备份脚本的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/143308.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月1日 18:28:46
下一篇 2025年12月1日 18:29:59

相关推荐

  • Solana,Dex卷和Memecoins:纽约人的拍摄

    索拉纳(Solana)的DEX音量激增,Memecoin波动和AI驱动的叙述创造了野生景观。是金融的未来还是一个奇怪的模因泡沫? Solana,Dex卷和Memecoins:纽约人的拍摄 Solana一直在浪潮,超越了Dex量的以太坊,并成为Memecoins的游乐场。但这都是阳光和玫瑰吗?让我们潜…

    2025年12月8日
    000
  • XRP,Cardano和Magacoin Finance:在2025年绘制加密课程

    在不断演变的2025年加密货币市场中,xrp和cardano等老牌altcoins正积极应对监管环境的变化并逐步推进发展,而magacoin finance等新兴项目则吸引了大量投资者的关注。 XRP:监管明朗化与ETF预期推动发展 随着法律不确定性的逐渐消退,XRP正在获得机构投资者的青睐。加拿大…

    2025年12月8日
    000
  • Clanker Crypto:关于这个2025代币创建工具,您需要了解的一切

    clanker crypto在2025年掀起了一股热潮,通过简化erc-20代币的创建流程,让每一个人都能轻松参与。这个平台以base链为基础,注重用户体验和社区驱动,迅速赢得了广泛关注。以下是关于它的一切你需要知道的内容。 Clanker Crypto:2025年代币生成工具全解析 在快速变化的加…

    2025年12月8日
    000
  • Ruvi AI:Cardano继任者提供大量的投资回报率预测?

    ruvi ai正迅速崛起,被视为一个具有潜力的加密货币项目,其发展轨迹与cardano早期阶段的爆发极为相似。借助人工智能技术的整合以及在现实世界中的应用能力,该项目被分析人士看好,预计可能带来可观的投资回报。 围绕Ruvi AI的讨论热度持续上升,有关其潜在实现13,800%投资回报率的说法开始引…

    2025年12月8日
    000
  • XRP Price,Chatgpt和2025 Bull Run:nyc Perspective

    xrp的法律挑战,chatgpt的影响以及2025年牛市的可能性:纽约人的观点 XRP价格、Chatgpt与2025年牛市:纽约视角 嘿,加密货币粉丝们!我们来聊聊XRP目前的情况,Chatgpt可能带来的影响,以及2025年的牛市是否真的在酝酿中。系好安全带,这将是一段充满起伏的旅程。 XRP面临…

    2025年12月8日
    000
  • Solana和4美元以下的加密宝石:在牛市上航行

    探索solana在4美元以下的机构吸引力与潜力加密货币(包括具备实用性的meme coins),为即将到来的2025年牛市寻找潜在回报机会。 Solana与低于4美元的加密宝藏:在牛市中航行 随着Solana成为2025年牛市关注的焦点,现在是时候挖掘一些可能具有爆发力的加密资产,特别是那些价格低于…

    2025年12月8日
    000
  • Web3 AI,价格预测和BCH潮:导航加密迷宫

    web3 ai融合了加密技术,超流动性币种的价格起伏以及比特币现金的行情波动。挖掘核心信息与可能的投资机遇。 探索加密货币领域有时像是破译古老的象形文字,尤其在像Web3 AI这样的新科技、价格波动预测和意外的市场趋势不断涌现的环境下。让我们来一一解析,用纽约式的直白方式。 Web3 AI:一体化加…

    2025年12月8日
    000
  • 云采矿:您获得财务自由和加密奖励的门票?

    探索hashj与miningtoken等云采矿平台如何通过加密货币奖励实现财务自由。这些机会是否真实可行? 云采矿:通往财务自由与加密奖励的途径? 云挖矿正变得炙手可热,承诺通过加密货币奖励实现财务自由。Hashj和MiningToken等平台正迅速崛起,但它们真的可靠吗?我们来深入了解。 云采矿的…

    2025年12月8日
    000
  • BL3 Token:这是AI Gaming的预售发布,以破坏传统工作室吗?

    block3的bl3代币预售正在引发广泛关注,可能将重塑ai游戏格局,并挑战传统游戏工作室的地位。立即了解最新动态! “BL3代币,AI游戏,预售启动”的热潮正迅速升温。Block3作为其中的重要参与者,致力于推动游戏创作的去中心化,并对传统游戏公司形成冲击。 Block3:AI游戏中的流动资产 B…

    2025年12月8日
    000
  • Ruvi AI:分析师将这个象征性当作下一个公牛奔跑的领导者

    分析师将目光投向ruvi ai(ruvi),认为其有望成为下一轮牛市的领头羊,原因在于其实用性与透明的发展路径。 Ruvi AI:被看作下一波牛市领涨者的潜力项目 随着市场对加密资产的兴趣不断转移,Ruvi AI(Ruvi)正逐渐进入分析师视野。让我们来看看这个结合人工智能与区块链技术的代币为何能引…

    2025年12月8日
    000
  • Robinhood and The Crypto Revolution:Micro Futures Edition

    robinhood在xrp、solana和bitcoin的micro futures中进一步深入加密货币领域,目标是成为金融超级应用程序。但是一切都进展顺利吗? 嘿,华尔街的想法来了? Robinhood最近在加密市场动作频频,不只是买入和持有那么简单。他们引入了微型期货,这可是个大动作。我们来纽约…

    2025年12月8日
    000
  • Sonic&Kaito:获得YAP的报酬约为$ S令牌!

    sonic携手kaito ai团队,推出围绕$ s代币空投的社交奖励机制。在x平台分享您的真知灼见,冲击yapper排行榜! 高性能第一层区块链Sonic正在掀起波澜。此次,他们与Kaito AI展开合作,旨在对围绕$ S代币及其生态系统的讨论进行激励。别再只是佩戴巫师帽了,现在,您的社交智慧也能带…

    2025年12月8日
    000
  • 安多佛(Andover)的青年开始刺激寻宝冒险

    探索andover的年轻人如何参与充满乐趣的寻宝活动,激发户外探险精神与社区凝聚力。 在安多佛(Andover),一股激动人心的热潮正席卷着年轻一代,他们纷纷加入到寻宝活动中。这些旨在促进户外探索和邻里互动的活动,已成为家庭和孩子们热衷的休闲方式。 发现安多弗的秘密宝藏:寻宝记 居住在安多弗的布伦丹…

    2025年12月8日
    000
  • 比特币选项,BTC和BTC Bull Token:看涨的前景?

    随着比特币期权到期和etf资金持续流入,btc bull token作为与比特币价格紧密相关的模因币崭露头角,目标直指25万美元的高点。预售即将结束! 比特币期权、BTC与BTC Bull Token:看涨趋势来临? 比特币生态正迎来新一轮热潮!在期权到期之际,叠加ETF强劲流入以及如BTC Bul…

    2025年12月8日
    000
  • Sonic,Kaito AI和$ s代币:区块链参与的新时代

    探索sonic、kaito ai与$s代币的最新动态,聚焦社区互动、技术创新及市场走势。 Sonic、Kaito AI与$S代币:区块链参与的新纪元 区块链、人工智能平台与创新代币机制的融合,正在开启前所未有的机遇。Sonic、Kaito AI与$S代币正站在这一变革的最前沿,各自在构建去中心化生态…

    2025年12月8日
    000
  • 7月要观看的十大加密投资:超越通常的嫌疑人

    探索7月有潜力的加密投资,超越sol和xrp等主流币种,寻找潜在的高增长机会。 7月值得关注的十大加密投资:不止于主流币种 随着7月的到来,加密市场正蓄势待发。虽然主流币种依然稳健,但精明的投资者正在挖掘那些被低估的代币,以寻求更高的回报。今年7月,关键在于跳出常规思维,发现具备不对称收益潜力的项目…

    2025年12月8日
    000
  • AltCoins,数据和上升的潜力:下一步是什么?

    最近的数据显示,山寨币可能正处在大幅上涨的前夕。多个关键指标显示出整理与积累的迹象,暗示着季节性机会的到来。 整个Altcoin市场弥漫着乐观情绪。在比特币创下历史新高之后,山寨币似乎也酝酿着强劲反弹。我们来看看推动这一趋势背后的因素。 山寨币成交量:看涨信号? 分析师Axel Adler近期提到了…

    2025年12月8日
    000
  • Wemix拥抱链链链接CCIP,用于跨链USDC:互操作性的新时代

    wemix升级其跨链游戏功能,采用chainlink ccip实现安全的usdc传输。降低这种改变行业格局的集成所带来的风险。 Wemix采用Chainlink CCIP实现跨链USDC:互操作性新纪元 Wemix正在区块链领域掀起波澜!通过引入Chainlink的跨链互操作性协议(CCIP),该平…

    2025年12月8日
    000
  • Grayscale Q3监视列表上的山寨币:什么是热,什么不是

    grayscale的q3观察名单已发布!看看哪些山寨币被剔除,哪些被下调,这又将对加密货币市场带来怎样的影响。 Grayscale Q3关注的山寨币:谁在风口,谁被冷落 Grayscale的Q3观察名单揭示了加密资产领域机构投资者的关注点。这份名单中包含哪些Altcoin?它又能为普通投资者提供什么…

    2025年12月8日
    000
  • 加密精选:Avalanche和Morpho使Grayscale的前20名使人们感到乐观!

    grayscale对其前20大加密资产进行了更新,重点关注雪崩(avax)和morpho。了解这些山寨币为何成为新宠,以及它们对整个加密市场的影响。 加密货币领域总是充满新的动态,最近的热点是Grayscale对其前20大加密资产的更新。雪崩(Avax)与Morpho被纳入榜单,而Optimism与…

    2025年12月8日
    000

发表回复

登录后才能评论
关注微信