Linux經過腳本實現遠程自動備份

考慮到在本機上備份數據,一旦該機器硬盤出現故障,數據沒法取出。遠程手動備份數據費時費力且不及 時。最好的方法就是經過腳本實現遠程自動互備。但遠程不管是經過SSH登錄,仍是經過scp拷貝文件都須要輸入密碼。爲了克服這個問題,首先須要實現不需 要密碼的SSH登錄,這樣就可使用rsync,scp,rexec等命令來作的遠程備份了。html

  1. 設置無需密碼的ssh登錄,方法以下:linux

  假設A,B兩服務器,如今須要在A機上用root登錄B機,而不須要輸入密碼,那咱們可按照下面的步驟來作:sql

  1)在A機上生成鑰匙對,執行如下命令:服務器

  ssh-keygen -t rsaoracle

  Generating public/private rsa key pair.ssh

  Enter file in which to save the key (/root/.ssh/id_rsa): /root/.ssh/id_rsaide

  Enter passphrase (empty for no passphrase):直接回車post

  Enter same passphrase again:直接回車測試

  Your identification has been saved in /root/.ssh/id_rsa.spa

  Your public key has been saved in /root/.ssh/id_rsa.pub.

  The key fingerprint is:

  f6:61:a8:27:35:cf:4c:6d:13:22:70:cf:4c:c8:a0:23 root@host1

  這樣,在/root/.ssh/路徑下會生成id_rsa,和id_rsa.pub,其中id_rsa是密鑰,id_rsa.pub是公鑰。

  2)把在A機生成的id_rsa.pub拷貝到B機上,假設拷貝到B機的臨時目錄下,如:

  scp /root/.ssh/id_rsa.pub root@218.242.214.20:/tmp

  3)用root賬號登錄B機,進入其主目錄,建立authorized_keys文件,並設置好權限。

  cd ~/.ssh

  cat /tmp/id_rsa.pub >>authorized_keys

  chmod 400 authorized_keys

  rm -f /tmp/id_rsa.pub

  4)測試

  在A機上轉到root賬號,嘗試登陸B機。看看是否是不要密碼.

  說明:

  authorized_keys文件的權限很重要,若是設置爲777,那麼登陸的時候,仍是須要提供密碼的。

  記得將臨時目錄下的id_rsa.pub刪除,養成個好習慣。

  本方法在Red Hat9.0上測試經過。

  2. 編輯crontab文件

  vi /etc/crontab

  如設置天天凌晨3:00執行cron.daily中的腳本:

  00 3 * * * root run-parts /etc/cron.daily

  3.編輯cron.daily中的腳本

  cd /etc/cron.daily/

  vi backupdb

  pg_dump -U postgres voipack > /voipack.sql

  pg_dump -U postgres regserver > /regserver.sql

  tar -cvjf /aavm.tgz.bz2 /usr/local/aavm

  tar -cvjf /oracle.tgz.bz2 /var/oracle

  scp /voipack.sql root@218.242.214.20:/root/218.242.214.23_backup

  scp /regserver.sql root@218.242.214.20:/root/218.242.214.23_backup

  scp /aavm.tgz.bz2 root@218.242.214.20:/root/218.242.214.23_backup

  scp /oracle.tgz.bz2 root@218.242.214.20:/root/218.242.214.23_backup

  將23上產生的備份文件copy到218.242.214.20:/root/218.242.214.23_backup路徑下

  一樣的方法能夠將假設B服務器上的數據備份到A服務器,實現雙機的互備。

本文章來自: 轉自中國IT實驗室 >> Linux >> 系統管理 >> 系統管理 >>

相關文章
相關標籤/搜索