1.安装sshpass,命令:
yum install -y sshpass
安装sshpass 后可以用sshpass+scp传输文件
由于有很多服务器需要批量传输时有什么办法?
可以用这个命令传输到www.txt文件到 192.168.0.178的home目录下
sshpass -p 123456 scp /home/www.txt root@192.168.0.178:/home (注:123456是密码)
2.如果没有成功,是因为第一次ssh让你输入yes
把 StrictHostKeyChecking no加到/etc/ssh/ssh_config可以让ssh客户端自动接受新主机的hostkey,不用
每次在ssh新主机时都自己输入yes
如下:
Host *
StrictHostKeyChecking no
3.如果你传输的文档是要替换服务器中本来就有的文档的话,有时候会出现替换的文档正在被服务器的进程所使用,则需要杀掉
改进程,拿我这里的服务器为例。我需要传输替换agvshell和jess这两个执行文件,但是这两个文件都在被执行,所以我写了个脚本先杀掉改这两个执行脚本的进程,再传输替换。如下:
#!/bin/bash
for((i=1;i<=50;i++)) #ip从192.168.1.1到192.168.1.50
do
sshpass -p 123456 ssh root@192.168.1.$i pkill agv_shell ;
sshpass -p 123456 ssh root@192.168.1.$i pkill jess ;
sshpass -p 123456 scp agv_shell root@192.168.1.$i:/opt/agv/ ;
sshpass -p 123456 scp jess root@192.168.1.$i:/opt/agv/ ;
sshpass -p 123456 ssh root@192.168.1.$i systemctl restart gzrobot.service ; #这条命令是我启agvshell和jess的命令
done