Linux 上使用 backup-manager 進行系統備份
| 2015-01-03 11:59 評論: 4 收藏: 5 分享: 9
無論簡單與否,我們都有機會去了解這麼一件事,那就是備份的重要性從來都不可以被低估。考慮到備份的方法真的多如牛毛,你可能想要知道怎樣來有效地為你的系統選擇正確的工具和和合適的策略。
在本文中,我將為你介紹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並按Enter鍵。
在下一步中,會詢問你要備份的所有目錄(用空格分隔)。建議,但不是嚴格要求,列出同一父目錄中的幾個子目錄,而不要僅僅輸入父目錄。
你可以跳過該步驟並在以後對配置檔案中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
小結
在本文中,我已經展示了備份管理器這個備份工具是怎樣的簡單而強大,並且易於使用。在你的備份策略中,你可能還有其它幾個選項需要考慮,請參閱手冊頁或使用者手冊,裡面也包含了幾個部署例項和建議。
希望此文對你有所幫助,請在下面隨意提問和評論。
via: http://xmodulo.com/linux-backup-manager.html
作者:Gabriel Cánepa 譯者:GOLinux 校對:wxy
相關文章
- 省時省力—在Linux系統上進行自動備份(轉)Linux
- 使用 rsync 來備份 Linux 系統Linux
- IBM AIX 無法進行系統備份IBMAI
- 容災備份 | 看我使用Powershell操作FTP進行資料檔案自動上傳備份FTP
- Elasticsearch 使用 NFS 進行資料備份ElasticsearchNFS
- 使用dd命令進行遠端備份
- Linux 系統的備份恢復Linux
- 安卓備份系統教程安卓備份系統教程安卓
- 使用Windows指令碼進行邏輯備份Windows指令碼
- 使用MySQL Workbench進行資料庫備份MySql資料庫
- Linux和類Unix系統上5個最佳開源備份工具Linux
- Linux 系統的備份與恢復Linux
- 使用mysqldump對mysql進行備份和恢復MySql
- 使用NetBackup進行oracle備份和恢復Oracle
- 使用xtrabackup對mysql進行備份和恢復MySql
- 使用 xtrabackup 進行MySQL資料庫物理備份MySql資料庫
- Backup And Recovery User's Guide-示例:在Linux或UNIX系統上使用dd工具備份GUIIDELinux
- 如何使用 rsync 備份 Linux 系統的一些介紹Linux
- aix系統備份AI
- 在Linux上使用的10種雲備份方案Linux
- mysqldump 進行資料備份MySql
- 用GHOST對LINUX系統做備份(轉)Linux
- Others——Linux系統備份及恢復(轉)Linux
- AIX作業系統下的用磁帶進行備份操作步驟AI作業系統
- 使用離線工具dmbackup進行資料庫備份資料庫
- 使用Handy Backup 6.2進行資料備份方法
- 使用OSB進行ORACLE rac資料庫的備份Oracle資料庫
- 使用mysqldump進行mysql資料庫備份還原MySql資料庫
- 備份&恢復系列之二:在linux中對oracle進行熱備份的指令碼!LinuxOracle指令碼
- 成功備份UNIX系統
- 使用scp在多個linux系統間進行copyLinux
- [Linux]經典面試題 - 系統管理 - 備份策略Linux面試題
- 圖形介面備份Linux系統介紹薦Linux
- linux系統備份方案--ghost網路篇(轉)Linux
- Linux系統備份及恢復 轉載 oldunixLinux
- 備份系統執行資料收集及分析的設計 | 運維進階運維
- windows10如何備份系統_windows10製作系統備份Windows
- 如何使用 backupninja 來備份 Debian 系統