Linux自动传输文件到另外一台服务器(SCP)
需求:定时传输服务器A上的某些文件到服务器B服务器A操作:[root@ctm9018 ~]# ssh-keygen -t rsa#生成秘钥[root@ctm9018 ~]# ssh-copy-id -i /root/.ssh/id_rsa.pub 192.168.157.166 #传输密码到目标服务器(本次传输需要输入目标服务器的密码)[root@ctm9018 ~]# ssh 192...
需求:定时传输服务器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的免密登陆。
更多推荐
所有评论(0)