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

运维 系统运维
考虑到在本机上备份数据,一旦该机器硬盘出现故障,数据无法取出。远程手动备份数据费时费力且不及时。最好的方法就是通过脚本实现远程自动互备。

考虑到在本机上备份数据,一旦该机器硬盘出现故障,数据无法取出。远程手动备份数据费时费力且不及时。最好的方法就是通过脚本实现远程自动互备。但远程无论是通过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服务器,实现双机的互备。

【编辑推荐】

  1. Linux和Windows系统线程间的区别
  2. Linux桌面的创新是否过于激进
  3. Linux程序设计殿堂的善意提醒
责任编辑:赵宁宁 来源: IT专家网
相关推荐

2011-03-28 16:12:55

mysql自动远程备份

2010-05-26 15:07:36

SVN版本库自动备份

2011-08-08 10:10:21

Linux备份

2012-09-28 13:39:40

Windows备份

2018-06-07 09:22:16

LinuxMysql备份

2021-09-22 09:55:20

LinuxMySQL数据库

2019-07-25 18:57:36

Linux数据库自动备份

2009-09-29 10:52:34

Linux自动备份操作系统

2021-09-10 07:48:22

Clickhouse数据库远程备份

2013-05-24 13:24:46

Mysql数据库自动备份

2022-08-11 07:07:46

系统Linux日志

2023-05-11 08:46:28

MySQL

2011-08-25 09:33:25

MySQL运维

2013-11-27 17:45:19

2023-03-02 23:45:23

linux开机启动Windows

2021-07-21 09:50:35

Linux脚本命令

2010-05-28 15:08:09

MySQL远程登陆

2009-08-12 18:16:37

Oracle数据库自动UNIX

2010-09-14 09:15:03

RsyncLinux备份远程数据同步

2011-08-24 15:16:37

Oracle数据库自动备份
点赞
收藏

51CTO技术栈公众号