閱讀93 返回首頁    go 技術社區[雲棲]


手把手教你利用命令行工具創建LinuxMac係統下的網站備份

手把手教你利用命令行工具創建LinuxMac係統下的網站備份

創建網站備份應該是一個網站管理員最為重要的日常工作之一。但現實情況是,備份這一步往往被很多人忽略,也就是說仍然有很多網管的網站安全意識較低。

所有的Linux/Mac用戶都能夠零經濟成本地通過命令行工具創建網站備份。如果你用的不是Linux/Mac,請關注我們的後續文章——如何在windows上通過軟件方式創建備份。

本文的初衷不是為讀者提供完整的備份解決方案,而是給那些有時間並且想要學習一些基礎的命令行工具進行網站備份的寶寶們一點參考。

必要條件

你的主機必須具備必要的軟件及證書。

(1) 服務器上的軟件:

  • tar

(2) 電腦上的軟件:

  • SSH(用於創建/刪除備份文件)
  • SCP(用於下載備份文件)
  • Terminal(例如gnome-terminal,用於運行所有命令)

(3) 所需信息

  • 服務器IP及SSH證書
  • 數據庫證書
  • 網站根目錄(以及你想在備份中加入或排除內容的目錄)
  • 數據庫:MySQL、PostgreSQL或SQLite(如果你的網站使用其中一種)

備份創建的具體步驟

一旦將你的電腦與服務器相連接,你就可以快速地通過命令進行網站備份。

(1) 通過SSH連接服務器:

SSH是Secure Shell的簡寫,通常用於遠程命令的執行。

2.gif

打開terminal,鍵入以下命令,通過SSH協議連入你的服務器:


  1. ssh username@serversIP 

在terminal中連上服務器後,你鍵入的每一條命令都在你的服務器上執行。接下來,我們要在服務器上創建一個名為“backup(備份)”的新文件夾。隻要不是公開的,你可以把這個文件夾放在任何地方。

如果你的web應用根目錄為:/home/username/html,那麼我們就能夠順利在 /home/username/中創建“backup(備份)”的文件夾。一旦備份傳輸到了電腦,就可以刪除服務器上的備份記錄。

如果你不知道自己的網站根目錄,可以在cPanel賬戶中找到該信息:

3.png

上圖中我們可以看到該網站的根目錄是:/home/ma658tvk。

在Linux/Mac操作係統中,你可以使用mkdir命令創建目錄。例如:


  1. mkdir -p /home/username/backup/{db,core,logs,conf} 

該命令能夠幫你在/home/username/中創建“backup”目錄。

在該文件夾中,我們已經創建了4個子目錄:db、core、logs以及conf。

注意mkdir命令中的-p符號,該符號表示:在某目錄已經存在但仍然按需創建主目錄的情況下不會報錯。

將整個應用進行備份的工作非常關鍵,包括數據庫轉儲文件、核心文件、插件以及媒體文件。如果你想更加細節化一些,還可以對服務器配置文件及日誌進行備份。在執行取證分析時,備份數據就更是尤為重要了。

導出數據庫

我之所以熱衷於使用命令行工具是因為在進行數據庫備份時都無需再用到其它附加工具。大多數的數據庫引擎都具備命令行功能,隻需要拿到數據庫證書,整個過程簡單粗暴高效。

4.gif

下麵的命令將導出一個數據庫轉儲文件並將其放在:/home/username/backup/db/

如果你的網站采用的是MySQL,可運行以下命令:


  1. mysqldump -u [database_user] -p [database_name] > [/home/username/backup/db/yourdomain.sql] 

若為PostgreSQL,則運行這個命令:


  1. pg_dump -U [database_user] [database_name] > [/home/username/backup/db/yourdomain.sql] 

這些命令會用到用戶名密碼。輸入後(你的terminal中看不到這些字符)轉儲文件將存儲在事先準備好的backup文件夾中。

如果網站用的是SQLite,那麼你隻需要複製該文件即可:


  1. cp [/path/to/your/SQLite.db] [/home/username/backup/db/] 

創建網站文件的Tar文件

現在我們要做的是壓縮網站核心文件(為了方便起見)。在你的服務器上安裝tar程序,並確定核心文件以及其它你想備份或不備份文件的具體位置。

我們再次假設你的網站存儲在:/home/username/html。那麼使用以下命令創建tar文件:


  1. tar -cf /home/username/backup/core/core.tar /home/username/html 

如果你想涵蓋/home/username/html中的所有文件,那麼上麵這個命令就非常好用。但如果你不想包含全部呢?

假設你的網站架構如下:


  1. html 
  2. ├── cache 
  3. ├── core 
  4. └── www 
  5.     ├── index.php 
  6.     └── media 

如果我們壓縮了整個目錄,那麼緩存(cache)文件夾也會被備份。而緩存文件完全沒有必要備份,如果刪除這部分內容,可以節省很多時間、節約帶寬。但如果使用tar命令,我們可以通過-exclude這一標識將不需要備份的目錄排除。下麵我們在排除緩存目錄的情況下對網站目錄進行再次壓縮:


  1. tar --exclude='/home/username/html/cache' -cf /home/username/backup/core/core.tar /home/username/html 

另外,名為core.tar的voilà – a .tar文件會存儲在/home/username/backup/core/中。你也可以一直使用-exclude命令對你不需要備份的內容進行排除。

可選:對配置或日誌文件進行備份

就個人經驗來說,我已經多次受益於配置和日誌文件的備份了。比如,我已經很多次忘記我的“httpd.conf”長啥樣了,所以每次我都通過查電腦上的備份來解決這個難題。我是一個很懶的人,但請諒解——這個習慣常常能幫上大忙,日誌文件也是。

配置文件和日誌文件沒有通用位置,但你可以在tar命令中添加多個位置。例如:


  1. tar -cf /home/username/backup/conf/conf.tar \ 
  2. /full/path/to/first_location \ 
  3. /full/path/to/second_location \ 
  4. /full/path/to/third_location 

第一行末尾的“\”符號表示按“Enter”鍵時,terminal不執行命令,而表示該命令含多行的意思。最後一行命令末尾不含“\”字符,表示terminal可以執行命令。這樣,你就可以創建一個包含你係統不同文件夾中的配置/日誌文件的.tar文件了。

隻要你在備份的服務器中安裝了正確的軟件,恢複配置文件隻會讓你對配置文件進行複製。如果要在生產服務器中恢複配置文件,但軟件不同,恢複過程可能會發生很多錯誤。務必小心。

最終備份

5.gif

(1) 創建最終的tar文件

到這裏,我們已經把/home/username/backup/文件夾下所需的文件都準備好了,現在我們隻需要創建.tar文件並把它下載到我們自己的電腦上即可。雖然我們也可以在不壓縮的情況下下載整個備份文件夾,但是我還是建議以單個壓縮文件的方式下載(更加保險、安全)。


  1. tar -cf /home/username/latest.backup.tar /home/username/backup/ 

該命令將創建一個名為“latest.backup.tar”的文件,包含所有的備份文件。在terminal中輸入“exit”就能斷開個人電腦與服務器的連接。

(2) 通過SCP下載文件

我們需要通過scp命令來下載latest.backup.tar這個文件:


  1. scp username@serversIP:/home/username/latest.backup.tar /home/username/backups/domainname/backup_$(date +%Y%m%d_%H%M%S).tar 

該命令的作用就是從服務器上抓取該.tar文件,並將它下載到你電腦上“ /home/username/backups/domainname/”的文件夾,然後根據標準日期命令對該文件夾進行重命名(如backup_20170730_142422)。

(3) 從服務器中刪除備份

現在網站備份已經安全地躺在你的電腦裏了,我們也就可以放心地刪除服務器上的備份記錄了。

首先,通過SSH重新登錄服務器,運行以下命令:


  1. rm /home/username/latest.backup.tar 
  2. rm -rfi /home/username/backup/ 

上麵第一個命令的作用是刪除服務器上最後的tar文件,第二個命令用於幫助你從服務器遞歸地刪除備份文件夾。

警告!務必確保文件和文件夾路徑的準確性,因為要想恢複通過命令行刪除的東西非常困難,而且恢複難度也會隨著時間的增加而增加。一旦某文件被刪除,該文件的所有鏈接均被破壞,操作係統也會隨時釋放該文件所使用的的區塊。再次聲明:務必確認使用的路徑是正確的。

一旦你刪除了備份文件,就可以通過輸入exit退出服務器。

結論

整個網站備份過程完美完成!這不是一個完整的解決方案,但我想這是學習信息安全領域中備份技術的一個良好開端。


本文作者:Carrie_spinfo

來源:51CTO

最後更新:2017-11-03 15:04:08

  上一篇:go  應對安全漏洞:如何將LFI變為RFI
  下一篇:go  【TensorFlow開源2年官方回顧】下一個重要方向是分布式模型服務