赞
踩
scp可以实现服务器与服务器之间的数据拷贝。(from server1 to server2)
scp -r $pdir/$fname $user@hadoop$host:$pdir/$fname
命令 递归 要拷贝的文件路径/名称 目的用户@主机:目的路径/名称
scp -r jdk1.8.0_212/ song@hadoop103:/opt/model/
scp -r song@hadoop102:/opt/model/hadoop-3.1.3 /opt/model/
scp -r song@hadoop102:/opt/model/jdk1.8.0_212 song@hadoop104:/opt/model/
rsync主要用于备份和镜像。具有速度快、避免复制相同内容和支持符号链接的优点。
rsync和scp区别:用rsync做文件的复制要比scp的速度快,rsync只对差异文件做更新。scp是把所有文件都复制过去。
rsync -rvl $pdir/$fname $user@hadoop$host:$pdir/$fname
命令 选项参数 要拷贝的文件路径/名称 目的用户@主机:目的路径/名称
选项参数说明
-a 归档拷贝
-v 显示复制过程
-l 拷贝符号连接
rsync -av hadoop-3.1.3/ song@hadoop104:/opt/model/hadoop-3.1.3
循环复制文件到所有节点的相同目录下
在任何目录下都可以使用该命令的方式,一种是放在当前用户的bin目录下,另外一种就是自定义路径 配置到PATH下
在这里使用的是第一种,进入该目录/home/song/bin
mkdir bin
touch xsync
脚本内容
#!/bin/bash
#1. 判断参数个数
# 判断参数是否小于1
if [ $# -lt 1 ]
then
echo Not Enough Arguement!
exit;
fi
#2. 遍历集群所有机器
# 对102,103,104都进行分发
for host in hadoop102 hadoop103 hadoop104
do
echo ==================== $host ====================
#3. 遍历所有目录,挨个发送
for file in $@
do
#4. 判断文件是否存在
if [ -e $file ]
then
#5. 获取父目录
pdir=$(cd -P $(dirname $file); pwd)
#6. 获取当前文件的名称
fname=$(basename $file)
ssh $host "mkdir -p $pdir"
rsync -av $pdir/$fname $host:$pdir
# 如果不存在
else
echo $file does not exists!
fi
done
done
给与执行权限
对于系统文件,分发失败
使用绝对路径去执行脚本
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。