首先需要做到的是就是数据库文件,以及二进制日志文件全部放在单独的逻辑卷存储!

实现LVM逻辑卷,数据,二进制日志文件分离存放

一,创建逻辑卷步骤

(1),创建新分区

1,查看分区情况看看还剩多少空间

    [root@centos7 backup]# lsblk
    NAME   MAJ:MIN RM  SIZE RO TYPE MOUNTPOINT
    sda      8:0    0  200G  0 disk 
    ├─sda1   8:1    0    1G  0 part /boot
    ├─sda2   8:2    0   50G  0 part /
    ├─sda3   8:3    0    2G  0 part [SWAP]
    └─sda4   8:6    0    1G  0 part /app
    sr0     11:0    1  8.1G  0 rom  
#我这个磁盘200G,用了54G,还剩146G

2,创建1个新的分区,当做逻辑卷

    fdisk /dev/sda 
    p  查看分区列表
    n  创建分区
    根据需要填写
    t  修改id为逻辑卷
    8e 
    p  再次确认

3,同步分区

    partprobe #centos7这条命令就可搞定

4,查看分区是否出来

    [root@ansible-7 ~]# lsblk
    NAME   MAJ:MIN RM  SIZE RO TYPE MOUNTPOINT
    sda      8:0    0  200G  0 disk 
    ├─sda1   8:1    0    1G  0 part /boot
    ├─sda2   8:2    0   50G  0 part /
    ├─sda3   8:3    0    2G  0 part [SWAP]
    ├─sda4   8:4    0  512B  0 part 
    ├─sda5   8:5    0   20G  0 part /app
    └─sda6   8:6    0   10G  0 part 
    sr0     11:0    1  8.1G  0 rom  

(2),创建逻辑卷

1,将新分区加入PV卷

    #加入pv卷
        [root@ansible-7 ~]#pvcreate /dev/sda6
    #查看PV卷
        [root@ansible-7 ~]#pvs
        PV         VG Fmt  Attr PSize  PFree 
        /dev/sda6     lvm2 ---  10.00g 10.00g

2,将PV卷加入卷组

    #加入卷组
        [root@ansible-7 ~]#vgcreate vg0 /dev/sda6
    #查看卷组
        [root@ansible-7 ~]# vgs
        VG  #PV #LV #SN Attr   VSize   VFree  
        vg0   1   0   0 wz--n- <10.00g <10.00g

3,创建存放数据以及二进制日志文件的逻辑卷

    #1,创建存放数据的逻辑卷
    lvcreate -n mysqldata -L 3G vg0
    #2,创建存放二进制日志文件的逻辑卷
    lvcreate -n binlog -L 2G vg0
    #查看创建情况
    [root@ansible-7 ~]# lvs
    LV        VG  Attr       LSize Pool Origin Data%  Meta%  Move Log Cpy%Sync Convert
    binlog    vg0 -wi-a----- 2.00g                                                    
    mysqldata vg0 -wi-a----- 3.00g                          
    "注意:PV卷的空间一定不要用完,因为需要有存放快照的空间"

4,创建文件系统

    mkfs.xfs /dev/vg0/mysqldata
    mkfs.xfs /dev/vg0/binlog

(3),开机自动挂载

1,创建两个文件分别当挂载点

    mkdir -pv /mysql/data
    mkdir -pv /mysql/binlog

2,修改/etc/fstab文件

    blkid 查看两个分区的UUID
    #将两分区按照这个顺序填写:UUID 挂载点 文件系统 defaults 0 0 即可 
    vim /etc/fstab
    UUID=d30a59eb-9a20-4376-a6ed-d47cc4d66d05  /mysql/data            xfs     defaults        0 0
    UUID=ef9c6374-a9e0-457f-895a-bf456be0ed96 /mysql/binlog           xfs     defaults        0 0

3,挂载

    [root@ansible-7 ~]# mount -a
    [root@ansible-7 ~]# lsblk
    NAME              MAJ:MIN RM  SIZE RO TYPE MOUNTPOINT
    sda                 8:0    0  200G  0 disk 
    ├─sda1              8:1    0    1G  0 part /boot
    ├─sda2              8:2    0   50G  0 part /
    ├─sda3              8:3    0    2G  0 part [SWAP]
    ├─sda4              8:4    0  512B  0 part 
    ├─sda5              8:5    0   20G  0 part /app
    └─sda6              8:6    0   10G  0 part 
      ├─vg0-mysqldata 253:0    0    3G  0 lvm  /mysql/data
      └─vg0-binlog    253:1    0    2G  0 lvm  /mysql/binlog
    sr0                11:0    1  8.1G  0 rom  

二,实现数据以及二进制日志分离

1,修改两个目录权限

    chown -R mysql.mysql /mysql/

2,修改mysql配置文件

    vim /etc/my.cnf
    在[mysqld]这个语句块下修改这两项
    [mysqld]
    datadir=/mysql/data
    log_bin=/mysql/binlog/mysql-binlog

3,重启mariadb服务

    systemctl restart mariadb
    systemctl enable  mariadb

4,查看端口是否打开

    [root@ansible-7 ~]# ss -ntl |grep 3306
    LISTEN     0      50           *:3306                     *:*  

备份步骤

一,记录二进制日志当前备份位置

1,锁表防止备份时数据变动

    flush tables with read lock;

2,记录二进制日志文件及事件位置

#1,刷新二进制日志
    flush logs;
#2,查看当前二进制日志位置
    show master status;
    MariaDB [(none)]> show master logs;
     Log_name                   File_size 
     mysql-binlog.000001            32644
     mysql-binlog.000002          31231291
     mysql-binlog.000003            245 

3,将二进制日志文件当前备份位置存入文件保存,用作以后恢复查看

#1,创建存放备份数据,以及日志的目录
    [root@ansible-7 data]#mkdir  /backup/binlog
    [root@ansible-7 data]#mkdir  /backup/data
#2,二进制日志文件当前备份位置存放至/backup/binlog目录里
    [root@ansible-7 ~]#mysql -uroot -p -e  'show master logs' >/mysql/binlog/pos-`date +%F`.log

    [root@ansible-7 ~]# cat /backup/binlog/pos-2018-03-07.log 
    Log_name    File_size
    mysql-binlog.000001      32644 
    mysql-binlog.000002   31231291
    mysql-binlog.000003     245

二,创建逻辑卷快照

#1,创建快照
    [root@ansible-7 data]#lvcreate -L 3G -s -p r -n mysqldata-snapshoot /dev/vg0/mysqldata

命令解析:
    -L:指定逻辑卷大小
    -s:指定该逻辑卷是快照
    -p:指定权限,r表示只有读权限
    -n:指定该逻辑卷名字
     /dav/vg0/mysqldata:表示针对该逻辑卷创建快照
#2,查看快照信息
    [root@ansible-7 ~]# lvdisplay 
     --- Logical volume ---
      LV Path                /dev/vg0/mysqldata-snapshoot
      LV Name                mysqldata-snapshoot
      VG Name                vg0
      LV UUID                CcaFOb-xLPT-pxh7-K9nP-MQP7-WFDm-gvPthA
      LV Write Access        read only
      LV Creation host, time ansible-7, 2018-03-07 14:30:04 +0800
      LV snapshot status     active destination for mysqldata
      LV Status              available
      # open                 0
      LV Size                3.00 GiB
      Current LE             768
      COW-table size         3.00 GiB
      COW-table LE           768
      Allocated to snapshot  0.00%
      Snapshot chunk size    4.00 KiB
      Segments               1
      Allocation             inherit
      Read ahead sectors     auto
      - currently set to     8192
      Block device           253:4

三,释放数据库锁,恢复用户访问

    unlock  tables;

四,挂载快照逻辑卷

#1,创建临时挂载目录
    [root@ansible-7 data]#mkdir  /snapshoot
#2,挂载
    [root@ansible-7 data]#mount -o nouuid,norecovery /dev/vg0/mysqldata-snapshoot /snapshoot
    "注意:xfs文件系统快照挂载需要指定nouuid,norecovery这两个选项,ext4不需要"

五,拷贝数据,达到备份目的

    tar cvf  /backup/data/all-`date +%F`.tar /snapshoot

六,备份完成删除快照逻辑卷

#1,取消挂载
    [root@ansible-7 data]#umount  /snapshoot
#2,删除快照逻辑卷
    [root@ansible-7 data]# lvremove /dev/vg0/mysqldata-snapshoot
    Do you really want to remove active logical volume vg0/mysqldata-snapshoot? [y/n]: y
    Logical volume "mysqldata-snapshoot" successfully removed

三,破坏数据库还原

(一),停止服务删除数据存放目录

    systemctl stop mariadb
    rm -rf /mysql/data/*

(二),恢复全备份数据

#1,解压缩
    tar vxf /backup/data/all-2018-03-07.tar
#2,复制snapshoot目录下的所有文件至/mysql/data/目录下
    cp -a snapshoot/* /mysql/data/

(三),用二进制日志还原至最新状态

1,查看之前存放在文件里的备份位置

    cat /backup/binlog/pos-2018-03-07.log
    Log_name    File_size
    mysql-binlog.000001 32644 
    mysql-binlog.000002 31231291
    mysql-binlog.000003 245
之前备份的位置是mysql-binlog.000002文件的 31231291位置
所以我们需要将mysql-binlog.000002日志文件拷贝出来

2,重新生成二进制日志文件,

    MariaDB [(none)]>flush logs

3,查看当前二进制日志文件位置

MariaDB [(none)]> show master logs;
    +---------------------+-----------+
    | Log_name            | File_size |
    +---------------------+-----------+
    | mysql-binlog.000001 |     32644 |
    | mysql-binlog.000002 |    312312 |
    | mysql-binlog.000003 |   1212312 |
    | mysql-binlog.000004 |       245 |
    +---------------------+-----------+
    3 rows in set (0.00 sec)

4,拷贝备份之后的相关二进制日志文件

    cp -a /mysql/binlog/mysql-binlog.000003 /backup/binlog/
    cp -a /mysql/binlog/mysql-binlog.000004 /backup/binlog/

5,将之前备份之后的内容取出来

    mysqlbinlog --start-position=245 mysql-binlog.000003 >bin.sql
    mysqlbinlog mysql-binlog.000004 >> bin.sql

(四),启动服务

    systemctl start mariadb

(五),暂停记录二进制日志功能

    set sql_log_bin=0;

(六),恢复二进制日志里的数据

    MariaDB [(none)]> source /backup/binlog/bin.sql

(七),开启记录二进制日志功能

    set sql_log_bin=1;

(八),恢复完了就可把拷贝的二进制日志文件删掉了,以免影响下次恢复