zoukankan      html  css  js  c++  java
  • MySQL三种备份

    一)备份分类

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    冷备:cold backup数据必须下线后备份
    温备:warm backup全局施加共享锁,只能读,不能写
    热备:hot backup数据不离线,读写都能正常进行
    备份的数据集
    完全备份:full backup
    部分备份:partial backup
    备份时的接口(是直接备份数据文件还是通过mysql服务器导出数据)
    物理备份:直接复制(归档)数据文件的备份方式:physical backup
    逻辑备份:把数据从库中提出来保存为文本文件:logical backup
    完全备份:full backup
    增量备份:incrementl backup
    差异备份:fidderential backup

    二)备份工具mysqldump讲解

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    mysqldump:逻辑备份工具
    InnoDB引擎热备,MyISM温备,Aria温备
    备份和恢复的过程比较慢,很难实现差异或增量备份
    恢复时,如果目标库不存在,需要事先手动创建
    常用选项:
    --all-databases:备份所有库
    --databases db1 db2...:备份指定的多个库
    注意:备份前要加锁:
    --lock-all-tables:请求锁定所有表之后在备份。
    --lock-tables:锁定指定的表。
    --single-transaction:能够对InnoDB存储引擎实现热备。
    备份代码:
    --events:备份事件调度器代码
    --routines:备份存储过程和存储函数
    --triggers:备份触发器
    备份时滚动日志:
    --flush-logs:备份前,请求到锁之后滚动日志。
    复制时的同步位置标记
    --master-data=【0|1|2
    0表示不记录
    1表示记录change master语句
    2记录为注释的change master语句
    使用mysqldump备份:
    请求锁:--lock-all-tables或使用--singe-transaction进行innoDB热备
    滚动日志:--flush-logs
    选定要备份的库:--databases
    记录二进制日志文件及位置:--master-data=0|1|2

    mysqldump三种备份方式:

    第一种:

    wKioL1NIFk3SEDI0AAKkXLygpwk752.jpg

    备份:[root@station141 ~]# mysqldump --databases benet > /tmp/benet.sql

    mysql> unlock tables;解锁

    mysql> drop database benet;删除库
    Query OK, 1 row affected (0.70 sec)

    恢复

    wKiom1NIFyDjIAYAAALGfdPcPvY533.jpg

    第二种方式备份:

    mysqldump --databases benet --lock-all-tables --flush-logs > /tmp/benet.sql直接备份的

    第三种方式备份:主要是针对innoDB引擎备份,实现热备。

    mysqldump --databases benet --single-transactions --flush-logs > /tmp/benet.3.sql

    备份所有数据库

    mysqldump --all-databases > /tmp/all.sql

    Xtrabackup备份工具使用如下:

    下载位置:http://www.percona.com/

    yum -y install percona-xtrabackup-2.1.8-733.rhel6.x86_64.rpm 

    yum -y install percona-toolkit-2.2.7-1.noarch.rpm 

    备份全部数据库: 

    innobackupex --user=root /myback 

    1
    2
    3
    4
    5
    6
    [root@localhost 2014-04-14_23-39-44]# cat xtrabackup_checkpoints
    backup_type = full-backuped
    from_lsn = 0
    to_lsn = 1619068
    last_lsn = 1619068
    compact = 0

    恢复数据库

    innobackupex --apply-log /mydata/2014-04-14_23-39-44/先把数据整理出来
    innobackupex --copy-back /mydata/2014-04-14_23-39-44/根据全备份恢复数据

    做增量备份

    innobackupex --incremental /mydata/ --incremental-basedir=/mydata/2014-04-14_23-39-44/

    基于上次的全备做

    1
    2
    3
    4
    5
    6
    [root@localhost 2014-04-14_23-45-11]# cat xtrabackup_checkpoints
    backup_type = incremental
    from_lsn = 1619068
    to_lsn = 1619478
    last_lsn = 1619478
    compact = 0

    查看是增量备份

    恢复增量备份,依次先恢复,全备,后增量

    1
    2
    3
    4
    innobackupex --apply-log --redo-only /mydata/2014-04-14_23-39-44/
    innobackupex --apply-log --redo-only /mydata/2014-04-14_23-39-44/ --incremental-dir=/mydata/2014-04-14_23-45-11/
    innobackupex --apply-log --redo-only /mydata/2014-04-14_23-39-44/ --incremental-dir=/mydata/2014-04-14_23-49-01/
    innobackupex --copy-back /mydata/2014-04-14_23-39-44/

     LVM-snapshot:基于lvm快照备份

    大致步骤:

        1)事务日志跟数据文件必须在同一个卷上

        2)创建快照卷之前,要请求mysql的全局锁,在快照创建完成之后释放锁

        3)请求全局锁完成之后,做一次日志滚动;做二进制日志及位置标记(手动进行);

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    [root@localhost ~]# mount
    /dev/mapper/vg0-root on / type ext4 (rw)
    proc on /proc type proc (rw)
    sysfs on /sys type sysfs (rw)
    devpts on /dev/pts type devpts (rw,gid=5,mode=620)
    tmpfs on /dev/shm type tmpfs (rw)
    /dev/sda1 on /boot type ext4 (rw)
    /dev/mapper/vg0-usr on /usr type ext4 (rw)
    /dev/mapper/vg0-var on /var type ext4 (rw)
    none on /proc/sys/fs/binfmt_misc type binfmt_misc (rw)
    sunrpc on /var/lib/nfs/rpc_pipefs type rpc_pipefs (rw)
    /dev/mapper/myvg-lvmy on /mnt type ext4 (rw)
    /mnt下放的就是mysql数据库得数
    1
    2
    3
    [root@localhost ~]# vim /etc/my.cnf
    thread_concurrency = 8
    datadir = /mnt

    安装数据库的时候先创建好个逻辑卷,安装目录为/mnt下。

    请求全局锁,滚动日志

    MariaDB [(none)]> flush tables with read lock;

    MariaDB [(none)]> flush logs;

    记录二进制日志位置

    mysql -e 'show master status' > mysql.txt

    创建快照

    [root@localhost ~]# lvcreate -L 1G -s -n mydata-snap -p r /dev/myvg/mydata 

    解锁

    MariaDB [(none)]> unlock tables;

    挂载快照并且备份

    mount /dev/myvg/mysql-snap /media/

    tar -Jcf /tmp.mysq.tar.xz /media/*

    卸载并删除快照

    1
    2
    3
    4
    [root@localhost ~]# umount /media/
    [root@localhost ~]# lvremove /dev/myvg/mysql-snap
    Do you really want to remove active logical volume mysql-snap? [y/n]: y
    Logical volume "mysql-snap" successfully removed
  • 相关阅读:
    hadoop下生成echarts关系图
    MongoDB实现增删查方法
    Hadoop中配置环境后重启失效解决方法
    Ubuntu中linux虚拟机全屏
    第二周第三天
    构建之法阅读笔记02
    第二周第二天
    第二周第一天
    学习进度条第五周
    第一周第七天
  • 原文地址:https://www.cnblogs.com/frankielf0921/p/5924365.html
Copyright © 2011-2022 走看看