Linux 上使用 backup-manager 进行系统备份
无论简单与否,我们都有机会去了解这么一件事,那就是备份的重要性从来都不可以被低估。考虑到备份的方法真的多如牛毛,你可能想要知道怎样来有效地为你的系统选择正确的工具和和合适的策略。
在本文中,我将为你介绍 backup-manager ,一个简单易用的命令行备份工具,在大多数的 Linux 发行版的标准软件库中都能见到它的身影。
是什么让备份管理器在众多的备份工具或备份策略中脱颖而出呢?让我来简单介绍一些它的与众不同的特性吧:
- 简单的设计与管理 :配置文件易于读懂和编辑,即便是初学者也很容易上手。
- 一劳永逸 :它在配置好后就可以通过 cron 周期性运作。
- 支持多种协议远程备份 :无缝整合多种传输协议、应用和云后端(如,FTP,SCP,SSH-GPG,rsync,AWS S3 等等)来传输生成的归档包到一组远程主机。
- 支持数据库备份 :包括支持开箱即用备份 MySQL/MariaDB 和 PostgreSQL 数据库。
- 支持加密 :备份过程中支持基于 GPG 文件的加密。
在 Linux 上安装备份管理器
备份管理器的安装是快速而无痛的,因为它就包含在大多数 Linux 发行版的基础软件库中。
Debian,Ubuntu 及其衍生版
# aptitude install backup-manager
在基于 Debian 的系统中安装时,会提示你输入要存放备份归档文件的目录。如果选择的目录不存在,那么当你首次运行备份管理器时它会自动创建。
选择 OK 并按回车键。
在下一步中,会询问你要备份的所有目录(用空格分隔)。建议,但不是严格要求,列出同一父目录中的几个子目录,而不要仅仅输入父目录。
你可以跳过该步骤并在以后对配置文件中 BM_TARBALL_DIRECTORIESb 变量进行设置。否则的话,就请尽可能多地添加你想要的目录,然后选择 OK:
Fedora 或 CentOS/RHEL
# yum install backup-manager
在 CentOS/RHEL 上,在运行以上 yum 命令前,你将需要先启用 EPEL 仓库 。
配置备份管理器
备份管理器的主配置文件是/etc/backup-manager.conf。该文件被划分为几个章节,里面定义了备份方法和相关的变量(或“键值”),这些配置让备份管理器成为一个多样化的工具,可以广泛地应付各种状况。
出于演示目的,我们将考虑以下环境:
- 每周对/etc,/home 以及/var/log 目录进行一次完整备份(我们将在下面通过 cron 设置备份的频率)。
- 通过 SSH 传输.tar.gz 备份归档文件到两台不同主机 dev1 和 dev3 上指定的目标目录。
- 通过 SSH 备份本地 MySQL 数据库到相同目标主机。
用你喜爱的文本编辑器打开/etc/backup-manager.conf 文件,并编辑以下变量。如果你愿意,你大可不必理会那些#开头的行。在本文中,它只是用作说明的注释:
# Specify the backup method(s) that will be used. # tarball: takes a list of directories and builds the corresponding tarballs. # mysql: archives MySQL databases using mysqldump. To restore the database, you # need to use the same tool manually. export BM_ARCHIVE_METHOD="tarball mysql" # Where to store the backups. export BM_REPOSITORY_ROOT="/var/archives" # The following directive indicates backup-manager to name # the generated files after the directory that was backed up. export BM_TARBALL_NAMEFORMAT="long" # Define the compression type for the generated files. export BM_TARBALL_FILETYPE="tar.gz" # List the directories that you want to backup. export BM_TARBALL_DIRECTORIES="/etc /home /var/log" # Exclude some subdirectories or file extensions. export BM_TARBALL_BLACKLIST="/var/log/myotherapp.log *.mp3 *.mp4" # List the database(s) that you want to backup, separated by spaces. export BM_MYSQL_DATABASES="mysql mybase wordpress dotclear phpbb2" # MySQL username. export BM_MYSQL_ADMINLOGIN="root" # MySQL password for username. export BM_MYSQL_ADMINPASS="mypassword" # Add support for DROP statements (optional). export BM_MYSQL_SAFEDUMPS="true" # The hostname or IP address where the database(s) reside. export BM_MYSQL_HOST="localhost" # Port where MySQL server is listening. export BM_MYSQL_PORT="3306" # Compression type (optional). export BM_MYSQL_FILETYPE="gzip" # Do not archive remote hosts, but only localhost. BM_TARBALL_OVER_SSH="false" # User account for SSH upload. export BM_UPLOAD_SSH_USER="root" # Absolute path of the user's private key for passwordless SSH login. export BM_UPLOAD_SSH_KEY="/root/.ssh/id_rsa" # Remote hosts (make sure you have exported your public key to them): export BM_UPLOAD_SSH_HOSTS="dev1 dev3" # Remote destination for uploading backups. If it doesn't exist, # this directory will be created automatically the first time # backup-manager runs. export BM_UPLOAD_SSH_DESTINATION="/var/archives/backups/$HOSTNAME"
运行备份管理器
要手动运行备份管理器,请输入以下命令。你也可以选择添加‘-v’标识以便一步一步详细检查运行过程。
# backup-manager
BM_TARBALL_DIRECTORIES 列出的目录将作为 tarball 备份到 BM_REPOSITORY_ROOT 目录,然后通过 SSH 传输到 BM_UPLOAD_SSH_DESTINATION 指定的主机 dev1 和 dev3。
正如你在上面图片中看到的那样,备份管理器在运行的时候创建了一个名为/root/.back-manager_my.cnf 的文件,MySQL 密码通过 BM_MYSQL_ADMINPASS 指定。那样,mysqldump 可以验证到 MySQL 服务器,而不必在命令行以明文格式接受密码,那样会有安全风险。
通过 cron 运行备份管理器
一旦决定哪一天是进行每周备份的最佳日子(最佳时间),你可以让 cron 来为你运行备份管理器。
打开 root 的 crontab 文件(注意,你必须以 root 登录):
# crontab -e
假定你想要在星期天的上午 5:15 分运行备份管理器,那么就添加下面这行。
15 05 * * 0 /usr/sbin/backup-manager > /dev/null 2>&1
小结
在本文中,我已经展示了备份管理器这个备份工具是怎样的简单而强大,并且易于使用。在你的备份策略中,你可能还有其它几个选项需要考虑,请参阅手册页或用户手册,里面也包含了几个部署实例和建议。
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

上一篇: 基于 Docker 的 PHP 开发环境
下一篇: 彻底找到 Tomcat 启动速度慢的元凶
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论