目的:每天将A服务器(192.168.0.23)上的文件复制到B服务器(192.168.0.25)上,如果已经存在则不复制。
思路:
首先统一服务器时间,避免出现莫名的错误或者管理上的混乱。用NTP
由于是跨服务器复制,涉及到密码自动录入的问题。需要解决。
用scp复制,会覆盖已经存在的文件,增加无用的工作。改用rsync。
由于要定时自动执行命令,需要用到crontab。
解决步骤:
解决时间同步问题
用ntpdate 192.168.0.253将内部NTP服务器的时间同步过来。为了以后的自动执行的时间同步,在/etc/ntp.conf内,添加NTP服务器:
vi /etc/ntp.conf
server 192.168.0.253
:x
解决密码自动录入问题
参考网址:http://blog.sina.com.cn/s/blog_8ad7d4ca01014lft.htm
有两种方法,一是用expect,需要安装。一是用密钥文件。这里用第二种密钥文件。
在A服务器上执行如下命令来生成配对密钥:(用oracle用户)
ssh-keygen -t rsa
遇到提示回车默认即可,公钥被存到用户目录下.ssh目录,比如root存放在:/root/.ssh/id_rsa.pub,oracle存放在:/home/oracle/.ssh
将 .ssh 目录中的 id_rsa.pub 文件复制到 B 的 ~/.ssh/ 目录中,并改名为 authorized_keys。
[oracle@NcDB .ssh]$ scp id_rsa.pub 192.168.0.25:/home/oracle/.ssh/authorized_keys
用rsync复制测试:
rsync -avzu /root/.ssh/id_rsa 192.168.0.25:/backup/ncbackup
将此命令写入cron服务内:
crontab -e
00 2 * * * /bin/bash /backup/autobkp/shfile/fullbak.sh 00 6 * * * /usr/bin/rsync -avzu /backup/autobkp/database/* 192.168.0.25:/backup/ncbackup/database/ 00 8 * * * /usr/bin/rsync -avzu /backup/autobkp/archlog/* 192.168.0.25:/backup/ncbackup/archlog 00 9 * * * /usr/bin/rsync -avzu /backup/autobkp/ctlfile/* 192.168.0.25:/backup/ncbackup/ctlfile
参考:http://www.blogjava.net/decode360/archive/2009/09/18/287743.html
转载于:https://blog.51cto.com/mister/1740752