新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計應(yīng)用 > Linux 下通過腳本實(shí)現(xiàn)遠(yuǎn)程自動備份

Linux 下通過腳本實(shí)現(xiàn)遠(yuǎn)程自動備份

作者: 時間:2012-07-10 來源:網(wǎng)絡(luò) 收藏

考慮到在本機(jī)上數(shù)據(jù),一旦該機(jī)器硬盤出現(xiàn)故障,數(shù)據(jù)無法取出。手動數(shù)據(jù)費(fèi)時費(fèi)力且不及時。最好的方法就是互備。但無論是SSH登陸,還是scp拷貝文件都需要輸入密碼。為了克服這個問題,首先需要不需要密碼的SSH登陸,這樣就可以使用rsync,scp,rexec等命令來做的遠(yuǎn)程了。

本文引用地址:http://butianyuan.cn/article/148791.htm

1. 設(shè)置無需密碼的ssh登陸,方法如下:

假設(shè)A,B兩服務(wù)器,現(xiàn)在需要在A機(jī)上用root登陸B(tài)機(jī),而不需要輸入密碼,那我們可按照下面的步驟來做:

1)在A機(jī)上生成鑰匙對,執(zhí)行以下命令:

ssh-keygen -t rsa

Generating public/private rsa key pair.

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

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

Enter same passphrase again:直接回車

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

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機(jī)生成的id_rsa.pub拷貝到B機(jī)上,假設(shè)拷貝到B機(jī)的臨時目錄下,如:

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

3)用root帳號登陸B(tài)機(jī),進(jìn)入其主目錄,創(chuàng)建authorized_keys文件,并設(shè)置好權(quán)限。

cd ~/.ssh

cat /tmp/id_rsa.pub >>authorized_keys

chmod 400 authorized_keys

rm -f /tmp/id_rsa.pub

4)測試

在A機(jī)上轉(zhuǎn)到root帳號,嘗試登錄B機(jī)??纯词遣皇遣灰艽a.

說明:

authorized_keys文件的權(quán)限很重要,如果設(shè)置為777,那么登錄的時候,還是需要提供密碼的。

記得將臨時目錄下的id_rsa.pub刪除,養(yǎng)成個好習(xí)慣。

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

2. 編輯crontab文件

vi /etc/crontab

如設(shè)置每天凌晨3:00執(zhí)行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上產(chǎn)生的備份文件copy到218.242.214.20:/root/218.242.214.23_backup路徑下

同樣的方法可以將假設(shè)B服務(wù)器上的數(shù)據(jù)備份到A服務(wù)器,雙機(jī)的互備。

linux操作系統(tǒng)文章專題:linux操作系統(tǒng)詳解(linux不再難懂)


評論


相關(guān)推薦

技術(shù)專區(qū)

關(guān)閉