您好,欢迎来到思海网络,我们将竭诚为您提供优质的服务! 诚征网络推广 | 网站备案 | 帮助中心 | 软件下载 | 购买流程 | 付款方式 | 联系我们 [ 会员登录/注册 ]
促销推广
客服中心
业务咨询
有事点击这里…  531199185
有事点击这里…  61352289
点击这里给我发消息  81721488
有事点击这里…  376585780
有事点击这里…  872642803
有事点击这里…  459248018
有事点击这里…  61352288
有事点击这里…  380791050
技术支持
有事点击这里…  714236853
有事点击这里…  719304487
有事点击这里…  1208894568
有事点击这里…  61352289
在线客服
有事点击这里…  531199185
有事点击这里…  61352288
有事点击这里…  983054746
有事点击这里…  893984210
当前位置:首页 >> 技术文章 >> 文章浏览
技术文章

Linux通过脚本实现远程自动备份

添加时间:2010-11-27  添加: admin 
 考虑到在本机上备份数据,一旦该机器硬盘出现故障,数据无法取出。远程手动备份数据费时费力且不及时。最好的方法就是通过脚本实现远程自动互备。但远程无论是通过SSH登陆,还是通过scp拷贝文件都需要输入密码。为了克服这个问题,首先需要实现不需要密码的SSH登陆,这样就可以使用rsync,scp,rexec等命令来做的远程备份了。

  1. 设置无需密码的ssh登陆,方法如下:

  假设A,B两服务器,现在需要在A机上用root登陆B机,而不需要输入密码,那我们可按照下面的步骤来做:

  1)在A机上生成钥匙对,执行以下命令:

  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机生成的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服务器,实现双机的互备。

 

分享到:

顶部 】 【 关闭
版权所有:佛山思海电脑网络有限公司 ©1998-2024 All Rights Reserved.
联系电话:(0757)22630313、22633833
中华人民共和国增值电信业务经营许可证: 粤B1.B2-20030321 备案号:粤B2-20030321-1
网站公安备案编号:44060602000007 交互式栏目专项备案编号:200303DD003  
察察 工商 网安 举报有奖  警警  手机打开网站