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 >> 系统管理 >> 系统管理 >>

相关文章
相关标签/搜索