#自定义的scp 多个主机shell 无参数修改传输文件可用
#!/bin/bash
array=( 10.66.1.205 10.66.1.207)
for(( i=0;i<${#array[@]};i++)) do
#${#array[@]}获取数组长度用于循环
echo ${array[i]};
scp scpall2.sh ${array[i]}:/root/code
done;
-------------------------------------参数写入 file写入-f file ,路径修改$path
#!/bin/bash
if [ "$#" -ne 2 ] ; then
echo "USAGE: $0 -f file"
exit 1
fi
echo $2
path='/root/code'
echo $path
array=( 10.66.1.205 10.66.1.207 10.66.1.216)
for(( i=0;i<${#array[@]};i++)) do
#${#array[@]}获取数组长度用于循环
echo ${array[i]};
scp $2 ${array[i]}:$path
done;
--------------------转载别人的shell -f 参数 不知道为什么老报错
#!/bin/bash
if [ "$#" -ne 2 ] ; then
echo "USAGE: $0 -f cmd"
exit 1
fi
# set server.list as parameter if nessesary
file_name='server.list'
cwd=$(pwd)
cd $cwd
serverlist_file="$cwd/$file_name"
if [ ! -e $serverlist_file ] ; then
echo '$file_name not exist'
exit 0;
fi
while read line
do
if [ -n "$line" ] ; then
echo "SCP --->" $line "<---"
if [[ $line =~ /$ ]] ; then
scp -r $1 root@$line:$2
else
scp $1 root@$line:$2
fi
if [ $? -eq 0 ] ; then
echo "scp $1 to root@$line:$2 done!"
else
echo "error: " $?
fi
fi
done < $serverlist_file
保存名为scpAll.sh
在相同的目录下面建一个server.list
文件夹,写入服务器列表:
hadoop01
hadoop02
hadoop03
然后把shAll.sh
变为可执行文件:
chmod -x ./scpAll.sh
然后就可以同时向所有服务器做scp传输了:
./scpAll.sh './scpAll.sh' '~/scpAll.sh'
作者:悠扬前奏
链接:https://www.jianshu.com/p/12ac36fa4651
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
-----------------------scp基础备忘
实例
1、从本地复制到远程
命令格式:
scp local_file remote_username@remote_ip:remote_folder
或者
scp local_file remote_username@remote_ip:remote_file
或者
scp local_file remote_ip:remote_folder
或者
scp local_file remote_ip:remote_file
- 第1,2个指定了用户名,命令执行后需要再输入密码,第1个仅指定了远程的目录,文件名字不变,第2个指定了文件名;
- 第3,4个没有指定用户名,命令执行后需要输入用户名和密码,第3个仅指定了远程的目录,文件名字不变,第4个指定了文件名;
应用实例:
scp /home/space/music/1.mp3 [email protected]:/home/root/others/music
scp /home/space/music/1.mp3 [email protected]:/home/root/others/music/001.mp3
scp /home/space/music/1.mp3 www.runoob.com:/home/root/others/music
scp /home/space/music/1.mp3 www.runoob.com:/home/root/others/music/001.mp3
复制目录命令格式:
scp -r local_folder remote_username@remote_ip:remote_folder
或者
scp -r local_folder remote_ip:remote_folder
- 第1个指定了用户名,命令执行后需要再输入密码;
- 第2个没有指定用户名,命令执行后需要输入用户名和密码;
应用实例:
scp -r /home/space/music/ [email protected]:/home/root/others/
scp -r /home/space/music/ www.runoob.com:/home/root/others/
上面命令将本地 music 目录复制到远程 others 目录下。
2、从远程复制到本地
从远程复制到本地,只要将从本地复制到远程的命令的后2个参数调换顺序即可,如下实例
应用实例:
scp [email protected]:/home/root/others/music /home/space/music/1.mp3
scp -r www.runoob.com:/home/root/others/ /home/space/music/
说明
1.如果远程服务器防火墙有为scp命令设置了指定的端口,我们需要使用 -P 参数来设置命令的端口号,命令格式如下:
#scp 命令使用端口号 4588
scp -P 4588 [email protected]:/usr/local/sin.sh /home/administrator
2.使用scp命令要确保使用的用户具有可读取远程服务器相应文件的权限,否则scp命令是无法起作用的。
#自定义的shell
#!/bin/bash
array=( 10.66.1.205 10.66.1.207)
for(( i=0;i<${#array[@]};i++)) do
#${#array[@]}获取数组长度用于循环
echo ${array[i]};
scp scpall2.sh ${array[i]}:/root/code
done;