Linux 系統(tǒng)下通過腳本實(shí)現(xiàn)遠(yuǎn)程自動(dòng)備份
添加時(shí)間:2018-12-30 15:28:19
添加:
思海網(wǎng)絡(luò)
考慮到在本機(jī)上備份數(shù)據(jù),一旦該機(jī)器硬盤出現(xiàn)故障,數(shù)據(jù)無法取出。遠(yuǎn)程手動(dòng)備份數(shù)據(jù)費(fèi)時(shí)費(fèi)力且不及時(shí)。最好的方法就是通過腳本實(shí)現(xiàn)遠(yuǎn)程自動(dòng)互備。但遠(yuǎn)程無論是通過SSH登陸,還是通過scp拷貝文件都需要輸入密碼。為了克服這個(gè)問題,首先需要實(shí)現(xiàn)不需要密碼的SSH登陸,這樣就可以使用rsync,scp,rexec等命令來做的遠(yuǎn)程備份了。
1. 設(shè)置無需密碼的ssh登陸,方法如下:
假設(shè)A,B兩服務(wù)器,現(xiàn)在需要在A機(jī)上用root登陸B(tài)機(jī),而不需要輸入密碼,那我們可按照下面的步驟來做:
1)在A機(jī)上生成鑰匙對(duì),執(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/路徑下會(huì)生成id_rsa,和id_rsa.pub,其中id_rsa是密鑰,id_rsa.pub是公鑰。
2)把在A機(jī)生成的id_rsa.pub拷貝到B機(jī)上,假設(shè)拷貝到B機(jī)的臨時(shí)目錄下,如:
scp /root/.ssh/id_rsa.pub root@218.242.214.20:/tmp
3)用root帳號(hào)登陸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)測(cè)試
在A機(jī)上轉(zhuǎn)到root帳號(hào),嘗試登錄B機(jī)?纯词遣皇遣灰艽a.
說明:
authorized_keys文件的權(quán)限很重要,如果設(shè)置為777,那么登錄的時(shí)候,還是需要提供密碼的。
記得將臨時(shí)目錄下的id_rsa.pub刪除,養(yǎng)成個(gè)好習(xí)慣。
本方法在Red Hat9.0上測(cè)試通過。
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ù)器,實(shí)現(xiàn)雙機(jī)的互備。
關(guān)鍵字:Linux、系統(tǒng)、服務(wù)器、數(shù)據(jù)備份
新文章:
- CentOS7下圖形配置網(wǎng)絡(luò)的方法
- CentOS 7如何添加刪除用戶
- 如何解決centos7雙系統(tǒng)后丟失windows啟動(dòng)項(xiàng)
- CentOS單網(wǎng)卡如何批量添加不同IP段
- CentOS下iconv命令的介紹
- Centos7 SSH密鑰登陸及密碼密鑰雙重驗(yàn)證詳解
- CentOS 7.1添加刪除用戶的方法
- CentOS查找/掃描局域網(wǎng)打印機(jī)IP講解
- CentOS7使用hostapd實(shí)現(xiàn)無AP模式的詳解
- su命令不能切換root的解決方法
- 解決VMware下CentOS7網(wǎng)絡(luò)重啟出錯(cuò)
- 解決Centos7雙系統(tǒng)后丟失windows啟動(dòng)項(xiàng)
- CentOS下如何避免文件覆蓋
- CentOS7和CentOS6系統(tǒng)有什么不同呢
- Centos 6.6默認(rèn)iptable規(guī)則詳解