• Innobakcupex 代码解析



    #prepare
    check_args() && init()
     
    #start 
    #根据配置决定是进行 copy_back, apply_log , bakcup 三种模式中的哪一个
    #下面具体介绍backup中(即备份)的具体过程
    copy_back() or  apply_log() or backup()
     
    #以下是backup()函数中的内容
     
    #检查cmdline提供的连接参数是否能够连接MySQL 实例
    #并执行一句select语句,检测健康状态
    b.1 mysql_open();
    b.2 mysql_close();
     
    #该函数将调用xtrabackup进行备份。
    b.3 start_ibbackup();

    #fork一个子进程

    b.3.1 fork()

    #如果是父进程,则函数跳出,进入外层等待

    b.3.2 if I'm parent:  

    #如果是子进程,则调用外部可执行文件xtrabackup

    b.3.3 if I'm child: 

    execute(cmd_line);
     
    #等待ibbackup,直到innodb相关文件的备份结束,并生成suspend文件。
    b.4 wait_for_ibbackup_suspend();
    -------------------------------------------------------------------------------------------------------------
    #执行到这一行时,意味着xtrabackup相关的备份工作已经完成
    #创建了一个suspend文件,等待文件被删除后退出。
    #在退出之前,xtrabackup仍然会不断扫描iblogfile,记录新的redo log
    -------------------------------------------------------------------------------------------------------------
     
    #接着 ibbackup开始准备备份非 innodb类型的表
    #打开一个mysql命令管道,执行之后的所有mysql 命令
    #open(*MYSQL_WRITER, "| mysql $options >$mysql_stdout 2>$mysql_stderr ")
    b.5 mysql_open();  
     
    #如果配置了 safe-slave的参数,脚本会循环等待。
    #直到slave opened temp table =0,并stop slave  (如果是mmm环境不宜配置这个参数,否则会导致mmm切换
    b.6 wait_for_safe_slave();
     
    #如果没有显示的配置 no-lock,此段脚本会尝试获得一枚全局锁
    #保证非innodb类型表备份时的consistency
    b.7 if (!$option_no_lock) 

    #在添加全局锁之前,先用rsync备份一次所有文件
    #这样使得获得全局锁之后,只需要进行文件增量备份,以缩短全局锁时间。

    b.7.1 backup_files(1); 

     
    #正式开始获取全局锁的函数

    b.7.2 mysql_lockall();

    ------------------------------------------------全局锁开始分割线-------------------------------------------------------------
    #通过Flush 获得全局锁
    #由于Flush tables with read lock 会等待当前时间点前的所有事务的结束。详见链接
    #因此,此时如有通过start transaction发起的作业在运行时,Flush会等待作业的结束
    #并同时阻塞之后的所有读写请求。
    #即: long running transaction 和 innobackupex同时运行,会导致后者的阻塞,继而阻塞后续业务读写操作
    #如果非innodb引擎的表,不存放业务数据,则建议使用:no-lock参数
    b.7.2.1 mysql_send "FLUSH TABLES WITH READ LOCK;"; 
    b.7.2.2 mysql_send "COMMIT;";
    #记录当前binlog 信息
    b.7.2.3 write_binlog_info
    #记录用于change master 的信息
    b.7.2.4 write_slave_info
     
    #正式开始备份非innodb表,使用rsync
    #包括*.{frm,MYD,MYI,MRG,TRG,TRN,ARM,ARZ,CSM,CSV,opt,par} 类型文件
    b.8 backup_files ()
     
    #删除suspend-file以唤醒xtrabackup,copy这段时间内的logfile
    #同时,等待xtrabackup进程的结束
    b.9 resume_ibbackup
     
    #通过unlock tables 释放全局锁
    b.10 mysql_unlockall()
    ------------------------------------------------全局锁结束分割线-------------------------------------------------------------
     
    #如果配置了safe-slave 则重新start slave
    b.11 mysql_send('START SLAVE SQL_THREAD;');
     
    #关闭执行mysql命令用的管道

    b.12 mysql_close();

     

     

     

     

     

     

  • 相关阅读:
    Go 只读/只写channel
    MongoDB 倾向于将数据都放在一个 Collection 下吗?
    Go语言string,int,int64 ,float之间类型转换方法
    [转]流程自动化机器人(RPA)概念、原理与实践
    ESXi以及WorkStation缩减thin provision模式Linux虚拟机磁盘的方法
    Linux 安装宋体字体的简单办法
    浏览器性能简单测试
    学习面试题Day04
    学习面试题Day05
    学习面试题Day06
  • 原文地址:https://www.cnblogs.com/cenalulu/p/2499620.html
Copyright © 2020-2023  润新知