其实 xfsdump 的功能颇强!他除了可以进行文件系统的完整备份 (full backup) 之外,还可以进行累积备份 (Incremental backup) 喔! 啥是累积备份呢?这么说好了,假设你的 /home 是独立的一个文件系统,那你在第一次使用 xfsdump 进行完整备份后,等过一段时间的文件系统自然运行后, 你再进行第二次 xfsdump 时,就可以选择累积备份了!此时新备份的数据只会记录与第一次完整备份所有差异的文件而已。 看不懂吗?没关系!我们用一张简图来说明。

    图8.4.1、xfsdump 运行时,完整备份与累积备份示意图

    如上图所示,上方的“实时文件系统”是一直随着时间而变化的数据,例如在 /home 里面的文件数据会一直变化一样。 而下面的方块则是 xfsdump 备份起来的数据,第一次备份一定是完整备份,完整备份在 xfsdump 当中被定义为 level 0 喔!等到第二次备份时,/home 文件系统内的数据已经与 level 0 不一样了,而 level 1 仅只是比较目前的文件系统与 level 0 之间的差异后,备份有变化过的文件而已。至于 level 2 则是与 level 1 进行比较啦!这样了解呼?至于各个 level 的纪录档则放置于 /var/lib/xfsdump/inventory 中。

    • xfsdump 不支持没有挂载的文件系统备份!所以只能备份已挂载的!
    • xfsdump 必须使用 root 的权限才能操作 (涉及文件系统的关系)
    • xfsdump 只能备份 XFS 文件系统啊!
    • xfsdump 备份下来的数据 (文件或储存媒体) 只能让 xfsrestore 解析
    • xfsdump 是通过文件系统的 UUID 来分辨各个备份文件的,因此不能备份两个具有相同 UUID 的文件系统喔!
      xfsdump 的选项虽然非常的繁复,不过如果只是想要简单的操作时,您只要记得下面的几个选项就很够用了!

    特别注意, xfsdump 默认仅支持文件系统的备份,并不支持特定目录的备份~所以你不能用 xfsdump 去备份 /etc ! 因为 /etc 从来就不是一个独立的文件系统!注意!注意!

    • 用 xfsdump 备份完整的文件系统
      现在就让我们来做几个范例吧!假设你跟鸟哥一样有将 /boot 分区出自己的文件系统,要整个文件系统备份可以这样作:
    1. [root@study ~]# df -h /boot
    2. Filesystem Size Used Avail Use% Mounted on
    3. /dev/vda2 1014M 131M 884M 13% /boot # 挂载 /boot 的是 /dev/vda 设备!
    4. # 看!确实是独立的文件系统喔! /boot 是挂载点!
    5. # 2\. 将完整备份的文件名记录成为 /srv/boot.dump :
    6. [root@study ~]# xfsdump -l 0 -L boot_all -M boot_all -f /srv/boot.dump /boot
    7. xfsdump -l 0 -L boot_all -M boot_all -f /srv/boot.dump /boot
    8. xfsdump: using file dump drive_simple strategy
    9. xfsdump: version 3.1.4 dump format 3.0 - type ^C for status and control
    10. xfsdump: level 0 dump of study.centos.vbird:/boot # 开始备份本机/boot系统
    11. xfsdump: dump date: Wed Jul 1 18:43:04 2015 # 备份的时间
    12. xfsdump: session id: 418b563f-26fa-4c9b-98b7-6f57ea0163b1 # 这次dump的ID
    13. xfsdump: session label: "boot_all" # 简单给予一个名字记忆
    14. xfsdump: ino map phase 1: constructing initial dump list # 开始备份程序
    15. xfsdump: ino map phase 2: skipping no pruning necessary
    16. xfsdump: ino map phase 3: skipping only one dump stream
    17. xfsdump: ino map construction complete
    18. xfsdump: estimated dump size: 103188992 Bytes
    19. xfsdump: creating dump session media file 0 media 0, file 0
    20. xfsdump: dumping ino map
    21. xfsdump: dumping directories
    22. xfsdump: dumping non-directory files
    23. xfsdump: ending media file
    24. xfsdump: media file size 102872168 Bytes
    25. xfsdump: dump size non-dir files : 102637296 Bytes
    26. xfsdump: dump complete: 1 seconds elapsed
    27. xfsdump: Dump Summary:
    28. xfsdump: stream 0 /srv/boot.dump OK success
    29. xfsdump: Dump Status: SUCCESS
    30. # 在指令的下达方面,你也可以不加 -L 及 -M 的,只是那就会进入互动模式,要求你 enter!
    31. # 而执行 xfsdump 的过程中会出现如上的一些讯息,您可以自行仔细的观察!
    32. [root@study ~]# ll /srv/boot.dump
    33. -rw-r--r--. 1 root root 102872168 Jul 1 18:43 /srv/boot.dump
    34. [root@study ~]# ll /var/lib/xfsdump/inventory
    35. -rw-r--r--. 1 root root 5080 Jul 1 18:43 506425d2-396a-433d-9968-9b200db0c17c.StObj
    36. -rw-r--r--. 1 root root 312 Jul 1 18:43 94ac5f77-cb8a-495e-a65b-2ef7442b837c.InvIndex
    37. -rw-r--r--. 1 root root 576 Jul 1 18:43 fstab
    38. # 使用了 xfsdump 之后才会有上述 /var/lib/xfsdump/inventory 内的文件产生喔!

    这样很简单的就创建起来 /srv/boot.dump 文件,该文件将整个 /boot/ 文件系统都备份下来了! 并且将备份的相关信息 (文件系统/时间/session ID等等) 写入 /var/lib/xfsdump/inventory 中,准备让下次备份时可以作为一个参考依据。 现在让我们来进行一个测试,检查看看能否真的创建 level 1 的备份呢?

    • 用 xfsdump 进行累积备份 (Incremental backups)
      你一定得要进行过完整备份后 (-l 0) 才能够继续有其他累积备份 (-l 1~9) 的能耐!所以,请确定上面的实做已经完成! 接下来让我们来搞一搞累积备份功能吧!
    1. # 0\. 看一下有没有任何文件系统被 xfsdump 过的数据?
    2. [root@study ~]# xfsdump -I
    3. file system 0:
    4. fs id: 94ac5f77-cb8a-495e-a65b-2ef7442b837c
    5. session 0:
    6. mount point: study.centos.vbird:/boot
    7. device: study.centos.vbird:/dev/vda2
    8. time: Wed Jul 1 18:43:04 2015
    9. session label: "boot_all"
    10. session id: 418b563f-26fa-4c9b-98b7-6f57ea0163b1
    11. level: 0
    12. resumed: NO
    13. subtree: NO
    14. streams: 1
    15. stream 0:
    16. pathname: /srv/boot.dump
    17. start: ino 132 offset 0
    18. end: ino 2138243 offset 0
    19. interrupted: NO
    20. media files: 1
    21. media file 0:
    22. mfile type: data
    23. mfile size: 102872168
    24. mfile start: ino 132 offset 0
    25. mfile end: ino 2138243 offset 0
    26. media id: a6168ea6-1ca8-44c1-8d88-95c863202eab
    27. xfsdump: Dump Status: SUCCESS
    28. # 我们可以看到目前仅有一个 session 0 的备份数据而已!而且是 level 0 喔!
    29. # 1\. 先恶搞一下,创建一个大约 10 MB 的文件在 /boot 内:
    30. [root@study ~]# dd if=/dev/zero of=/boot/testing.img bs=1M count=10
    31. 10+0 records in
    32. 10+0 records out
    33. 10485760 Bytes 10 MB copied, 0.166128 seconds, 63.1 MB/s
    34. # 2\. 开始创建差异备份文件,此时我们使用 level 1 吧:
    35. [root@study ~]# xfsdump -l 1 -L boot_2 -M boot_2 -f /srv/boot.dump1 /boot
    36. ....(中间省略)....
    37. [root@study ~]# ll /srv/boot*
    38. -rw-r--r--. 1 root root 102872168 Jul 1 18:43 /srv/boot.dump
    39. -rw-r--r--. 1 root root 10510952 Jul 1 18:46 /srv/boot.dump1
    40. # 看看文件大小,岂不是就是刚刚我们所创建的那个大文件的容量吗? ^_^
    41. # 3\. 最后再看一下是否有记录 level 1 备份的时间点呢?
    42. [root@study ~]# xfsdump -I
    43. file system 0:
    44. fs id: 94ac5f77-cb8a-495e-a65b-2ef7442b837c
    45. session 0:
    46. mount point: study.centos.vbird:/boot
    47. device: study.centos.vbird:/dev/vda2
    48. ....(中间省略)....
    49. session 1:
    50. mount point: study.centos.vbird:/boot
    51. device: study.centos.vbird:/dev/vda2
    52. time: Wed Jul 1 18:46:21 2015
    53. session label: "boot_2"
    54. session id: c71d1d41-b3bb-48ee-bed6-d77c939c5ee8
    55. level: 1
    56. resumed: NO
    57. subtree: NO
    58. streams: 1
    59. stream 0:
    60. pathname: /srv/boot.dump1
    61. start: ino 455518 offset 0
    62. ....(下面省略)....

    通过这个简单的方式,我们就能够仅备份差异文件的部分啰!

    8.4.2 XFS 文件系统还原 xfsrestore

    • 用 xfsrestore 观察 xfsdump 后的备份数据内容
      要找出 xfsdump 的内容就使用 xfsrestore -I 来查阅即可!不需要加任何参数!因为 xfsdump 与 xfsrestore 都会到 /var/lib/xfsdump/inventory/ 里面去捞数据来显示的!因此两者输出是相同的!
    1. [root@study ~]# xfsrestore -I
    2. file system 0:
    3. fs id: 94ac5f77-cb8a-495e-a65b-2ef7442b837c
    4. session 0:
    5. mount point: study.centos.vbird:/boot
    6. device: study.centos.vbird:/dev/vda2
    7. time: Wed Jul 1 18:43:04 2015
    8. session label: "boot_all"
    9. session id: 418b563f-26fa-4c9b-98b7-6f57ea0163b1
    10. level: 0
    11. pathname: /srv/boot.dump
    12. mfile size: 102872168
    13. media label: "boot_all"
    14. session 1:
    15. mount point: study.centos.vbird:/boot
    16. device: study.centos.vbird:/dev/vda2
    17. time: Wed Jul 1 18:46:21 2015
    18. session label: "boot_2"
    19. session id: c71d1d41-b3bb-48ee-bed6-d77c939c5ee8
    20. level: 1
    21. pathname: /srv/boot.dump1
    22. mfile size: 10510952
    23. media label: "boot_2"
    24. xfsrestore: Restore Status: SUCCESS
    25. # 也看到这两个备份的数据他的内容大小!更重要的,就是那个 session label 喔!

    这个查询重点是找出到底哪个文件是哪个挂载点?而该备份文件又是什么 level 等等的!接下来,让我们实做一下从备份还原系统吧!

    • 简单复原 level 0 的文件系统
      先来处理一个简单的任务,就是将 /boot 整个复原到最原本的状态~你该如何处理?其实很简单,我们只要知道想要被复原的那个文件, 以及该文件的 session label name,就可以复原啦!我们从上面的观察已经知道 level 0 的 session label 是“boot_all”啰!那整个流程是这样:
    1. # 1\. 直接将数据给它覆盖回去即可!
    2. [root@study ~]# xfsrestore -f /srv/boot.dump -L boot_all /boot
    3. xfsrestore: using file dump drive_simple strategy
    4. xfsrestore: version 3.1.4 dump format 3.0 - type ^C for status and control
    5. xfsrestore: using online session inventory
    6. xfsrestore: searching media for directory dump
    7. xfsrestore: examining media file 0
    8. xfsrestore: reading directories
    9. xfsrestore: 8 directories and 327 entries processed
    10. xfsrestore: directory post-processing
    11. xfsrestore: restoring non-directory files
    12. xfsrestore: restore complete: 1 seconds elapsed
    13. xfsrestore: Restore Summary:
    14. xfsrestore: stream 0 /srv/boot.dump OK success # 是否是正确的文件啊?
    15. xfsrestore: Restore Status: SUCCESS
    16. # 2\. 将备份数据在 /tmp/boot 下面解开!
    17. [root@study ~]# mkdir /tmp/boot
    18. [root@study ~]# xfsrestore -f /srv/boot.dump -L boot_all /tmp/boot
    19. [root@study ~]# du -sm /boot /tmp/boot
    20. 109 /boot
    21. 99 /tmp/boot
    22. # 咦!两者怎么大小不一致呢?没关系!我们来检查看看!
    23. [root@study ~]# diff -r /boot /tmp/boot
    24. Only in /boot: testing.img
    25. # 看吧!原来是 /boot 我们有增加过一个文件啦!

    因为原本 /boot 里面的东西我们没有删除,直接复原的结果就是:“同名的文件会被覆盖,其他系统内新的文件会被保留”喔!所以, 那个 /boot/testing.img 就会一直在里头~如果备份的目的地是新的位置,当然就只有原本备份的数据而已啊!那个 diff -r 可以比较两个目录内的文件差异! 通过该指令我们可以找到两个目录的差异处!

    如果只想要复原某一个目录或文件的话,直接加上“ -s 目录 ”这个选项与参数即可!相当简单好用!

    • 复原累积备份数据
      其实复原累积备份与复原单一文件系统相似耶!如果备份数据是由 level 0 -> level 1 -> level 2… 去进行的, 当然复原就得要相同的流程来复原!因此当我们复原了 level 0 之后,接下来当然就要复原 level 1 到系统内啊! 我们可以前一个案例复原 /tmp/boot 的情况来继续往下处理:
    1. # 继续复原 level 1 到 /tmp/boot 当中!
    2. [root@study ~]# xfsrestore -f /srv/boot.dump1 /tmp/boot
    • 仅还原部分文件的 xfsrestore 互动模式
      刚刚的 -s 可以接部份数据来还原,但是…如果我就根本不知道备份文件里面有啥文件,那该如何选择啊?用猜的喔? 又如果要复原的文件数量太多时,用 -s 似乎也是笨笨的~那怎办?有没有比较好的方式呢?有的,就通过 -i 这个互动界面吧! 举例来说,我们想要知道 level 0 的备份数据里面有哪些东西,然后再少量的还原回来的话!
    1. # 1\. 先进入备份文件内,准备找出需要备份的文件名数据,同时预计还原到 /tmp/boot3 当中!
    2. [root@study ~]# mkdir /tmp/boot3
    3. [root@study ~]# xfsrestore -f /srv/boot.dump -i /tmp/boot3
    4. ========================== subtree selection dialog ==========================
    5. the following commands are available:
    6. pwd
    7. ls [ <path> ]
    8. cd [ <path> ]
    9. add [ <path> ] # 可以加入复原文件列表中
    10. delete [ <path> ] # 从复原列表拿掉文件名!并非删除喔!
    11. extract # 开始复原动作!
    12. quit
    13. help
    14. -> ls
    15. 455517 initramfs-3.10.0-229.el7.x86_64kdump.img
    16. 138 initramfs-3.10.0-229.el7.x86_64.img
    17. 141 initrd-plymouth.img
    18. 140 vmlinuz-0-rescue-309eb890d09f440681f596543d95ec7a
    19. 139 initramfs-0-rescue-309eb890d09f440681f596543d95ec7a.img
    20. 137 vmlinuz-3.10.0-229.el7.x86_64
    21. 136 symvers-3.10.0-229.el7.x86_64.gz
    22. 135 config-3.10.0-229.el7.x86_64
    23. 134 System.map-3.10.0-229.el7.x86_64
    24. 133 .vmlinuz-3.10.0-229.el7.x86_64.hmac
    25. 1048704 grub2/
    26. 131 grub/
    27. -> add grub
    28. -> add grub2
    29. -> add config-3.10.0-229.el7.x86_64
    30. -> extract
    31. [root@study ~]# ls -l /tmp/boot3
    32. -rw-r--r--. 1 root root 123838 Mar 6 19:45 config-3.10.0-229.el7.x86_64
    33. drwxr-xr-x. 2 root root 26 May 4 17:52 grub