关闭 x
IT技术网
    技 采 号
    ITJS.cn - 技术改变世界
    • 实用工具
    • 菜鸟教程
    IT采购网 中国存储网 科技号 CIO智库

    IT技术网

    IT采购网
    • 首页
    • 行业资讯
    • 系统运维
      • 操作系统
        • Windows
        • Linux
        • Mac OS
      • 数据库
        • MySQL
        • Oracle
        • SQL Server
      • 网站建设
    • 人工智能
    • 半导体芯片
    • 笔记本电脑
    • 智能手机
    • 智能汽车
    • 编程语言
    IT技术网 - ITJS.CN
    首页 » HTML5 »Linux 上使用 backup-manager 进行系统备份

    Linux 上使用 backup-manager 进行系统备份

    2015-03-25 00:00:00 出处:linux.cn
    分享

    无论简单与否,我们都有机会去了解这么一件事,那就是备份的重要性从来都不可以被低估。考虑到备份的方法真的多如牛毛,你可能想要知道怎样来有效地为你的系统选择正确的工具和和合适的策略。

    在本文中,我将为你介绍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

    小结

    在本文中,我已经展示了备份管理器这个备份工具是怎样的简单而强大,并且易于使用。在你的备份策略中,你可能还有其它几个选项需要考虑,请参阅手册页或用户手册,里面也包含了几个部署实例和建议。

    希望此文对你有所帮助,请在下面随意提问和评论。

    上一篇返回首页 下一篇

    声明: 此文观点不代表本站立场;转载务必保留本文链接;版权疑问请联系我们。

    别人在看

    hiberfil.sys文件可以删除吗?了解该文件并手把手教你删除C盘的hiberfil.sys文件

    Window 10和 Windows 11哪个好?答案是:看你自己的需求

    盗版软件成公司里的“隐形炸弹”?老板们的“法务噩梦” 有救了!

    帝国CMS7.5编辑器上传图片取消宽高的三种方法

    帝国cms如何自动生成缩略图的实现方法

    Windows 12即将到来,将彻底改变人机交互

    帝国CMS 7.5忘记登陆账号密码怎么办?可以phpmyadmin中重置管理员密码

    帝国CMS 7.5 后台编辑器换行,修改回车键br换行为p标签

    Windows 11 版本与 Windows 10比较,新功能一览

    Windows 11激活产品密钥收集及专业版激活方法

    IT头条

    无线路由大厂 TP-Link突然大裁员:补偿N+3

    02:39

    Meta 千万美金招募AI高级人才

    00:22

    更容易爆炸?罗马仕充电宝被北京多所高校禁用,公司紧急回应

    17:19

    天衍”量子计算云平台,“超算+量算” 告别“算力孤岛时代”

    18:18

    华为Pura80系列新机预热,余承东力赞其复杂光线下的视频拍摄实力

    01:28

    技术热点

    MySQL基本调度策略浅析

    MySQL使用INSERT插入多条记录

    SQL Server高可用的常见问题

    3D立体图片展示幻灯片JS特效

    windows 7上网看视频出现绿屏的原因及解决方法

    windows 7 64位系统的HOSTS文件在哪里?想用它加快域名解析

      友情链接:
    • IT采购网
    • 科技号
    • 中国存储网
    • 存储网
    • 半导体联盟
    • 医疗软件网
    • 软件中国
    • ITbrand
    • 采购中国
    • CIO智库
    • 考研题库
    • 法务网
    • AI工具网
    • 电子芯片网
    • 安全库
    • 隐私保护
    • 版权申明
    • 联系我们
    IT技术网 版权所有 © 2020-2025,京ICP备14047533号-20,Power by OK设计网

    在上方输入关键词后,回车键 开始搜索。Esc键 取消该搜索窗口。