在这里插入图片描述
需求:定时传输服务器A上的某些文件到服务器B

服务器A操作:

[root@ctm9018 ~]# ssh-keygen -t rsa #生成秘钥;此命令会在当前用户的家目录中自从创建名为.ssh的隐藏目录,并在.ssh目录下生成id_rsa(私钥)和id_rsa.pub(公钥)两个文件。
[root@ctm9018 ~]# ssh-copy-id 192.168.157.166 #将当前用户生成的公钥信息传输到目标服务器同名用户的家目录下(会在目标服务器同名用户家目录自动创建.ssh目录,并在目录下创建一个名为authorized_keys的文件用于与存储当前服务器的公钥信息)。这里需要注意的是:目标服务器一定要有一个同名用户,输入密码的时候输入的是目标服务器同名用户的密码。
[root@ctm9018 ~]# ssh 192.168.157.166 #测试SSH链接远程服务器不需要输入密码
[root@ctem02 ~]# exit #退出密钥登陆测试
[root@ctm9018 tmp]# touch /tmp/a{1..10}.txt #创建测试文件
[root@ctm9018 tmp]# vim filescp.sh #创建脚本,内容如下

#!/bin/bash
scp /tmp/a*.txt root@192.168.157.166:/tmp/

[root@ctm9018 tmp]# chmod 755 filescp.sh #赋权
[root@ctm9018 tmp]# crontab -e #加入脚本执行到计划任务

*/1 * * * * /tmp/filescp.sh

服务器B操作:
[root@ctem02 tmp]# ls -l /tmp/ #检测文件是否成功传输

扩展说明
这里使用的是ssh密钥的方式来实现免密登陆的,所以即便是两边的服务器都修改了root用户的密码,不会影响ssh的免密登陆。

Logo

更多推荐