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

1
回复
424
查看
[复制链接]
发表于 2014-2-4 23:35:57 | 显示全部楼层 |阅读模式
  为了防止数据丢失我们常常做的就是在电脑上备份这些数据,不过虽说备份了数据比较安全,但是万一数据所在的电脑发生问题怎么办呢,考虑到在本机上备份数据,一旦该机器硬盘出现故障,数据无法取出。远程手动备份数据费时费力且不及时。最好的方法就是通过脚本实现远程自动互备。但远程无论是通过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删除,养成个好习惯。
<p>          本方法在Red Hat9.0上测试通过。
 楼主| 发表于 2014-2-4 23:35:57 | 显示全部楼层
</p>          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服务器,实现双机的互备。
          这个方法主要是基于linux系统的,至于对于微软的系统有没有效果这个大家可以去试试,如果你安装的是linux系统的话大可以之家用以上的办法来实现。
关注官方微信

微信号:大白网

微博:大白网

QQ1群:4731622

QQ2群:4731622

全国服务热线:

QQ24485416

(工作日:周一至周五 9:00-16:00)
大理市
www@dali8.net

手机版-小黑屋- 大理白族|大理乡村旅游网|大理网|大理论坛|白族网|大理旅游网|大理信息网|大理生活网

技术支持:挖主机网络 Powered by大白网© 2006-2025 dalibaizu.com  滇ICP备19004088号 滇公网安备 53290102000530号