当前位置: 代码网 > 服务器>服务器>Linux > linux如何编写同步文件的脚本

linux如何编写同步文件的脚本

2024年07月03日 Linux 我要评论
linux编写同步文件的脚本搭集群最麻烦的就是修改配置文件,如果只用修改一个机器上的配置文件,然后用一个脚本就可以把配置文件同步到其他机器上,岂不快哉!编写一个名为xsync的脚本文件作用: 将当前机

linux编写同步文件的脚本

搭集群最麻烦的就是修改配置文件,如果只用修改一个机器上的配置文件,然后用一个脚本就可以把配置文件同步到其他机器上,岂不快哉!

编写一个名为xsync的脚本文件

作用: 将当前机器的文件,同步到集群所有机器的相同路径下!

hadoop102:/a/a , 执行脚本后,将此文件同步到集群中所有机器的 /a/a

用户在使用xsync时,只需要传入要同步的文件即可

xysnc a

不管a是一个相对路径还是绝对路径,都需要将a转换为 绝对路径

文件的 绝对路径=父路径+文件名

  • 父路径: dirpath=$(cd dirname /home/atguigu/hi; pwd -p)
  • 文件名: filename=basename hi

pwd的 -p参数是为了避免出现软链接导致的路径问题,-p可以使软链接显示出真实的链接

  • 核心命令:
	for(())
		do
			rsync -rvlt   path1 
		done
  • 正式文件:
#!/bin/bash
#校验参数是否合法
if(($#==0))
then
	echo 请输入要分发的文件!
	exit;
fi
#获取分发文件的绝对路径
dirpath=$(cd `dirname $1`; pwd -p)
filename=`basename $1`

echo 要分发的文件的路径是:$dirpath/$filename

#循环执行rsync分发文件到集群的每条机器
for((i=101;i<=103;i++))
do
	echo ---------------------hadoop$i---------------------
	rsync -rvlt $dirpath/$filename  username@hostname$i:$dirpath
done

最后别忘了把xcall文件放进 家目录下的bin目录

如果没有就新建一个bin目录

因为这目录是在 全局环境变量 

放进去后无论在哪个目录下都可以执行这个脚本文件!

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持代码网。

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com