这是我参与11月更文挑战的第6天,活动详情查看:2021最后一次更文挑战
背景
在运维或在日常工作生活中,我们经常会把一个文件拷贝到其它服务器上,或同时分发到多个服务器上,甚至要求目标机将文件放在相同的路径下,方便程序进一步调用。
遇到这种问题,我们通常的做法是使用scp或rsync命令把文件拷贝一个一个地拷贝到多台服务器上,这样做费时费力;大神的做法是使用ansible的playbook一下把事情干完,前提是你得会ansible;快捷的做法就是使用今天的脚本了。
效果演示
目前拥有4台机器,分别为client、node1、node2和node3,client与其它3台机器能够建立ssh链接。在client的/root/test目录下有a.txt和b.txt两个文件。
1 | bash复制代码[root@client test]# ls /root/test/ |
我把文件分发到node1、node2和node3的/root/test下,执行以下命令:
1 | bash复制代码# 在/root/test目录下执行, xrsync是我的脚本 |
执行分发过程:
1 | python复制代码[root@client test]# xrsync a.txt b.txt |
到node2上看一下,文件果然存在。同样地,node3和node4也同步过去了。
1 | csharp复制代码# node2上查看 |
脚本奉上
整个脚本的代码,只需要把其中的node1 node2 node3修改为自己环境下的主机名或ip地址即可。
1 | bash复制代码#!/bin/bash |
运行条件
为了更方便脚本的运行,建议使用如下优化。
1.修改/etc/hosts文件,加入IP地址与主机名的对应关系,这样方便我们使用主机名直接操作。比如我演示的机器配置。
1 | bash复制代码vim /etc/hosts |
2.客户机与目标机之间使用ssh密码验证登录,这样在传输文件时不需要二次验证。
1 | bash复制代码# 生成ssh私钥 |
3.给脚本加可执行权限,并配置环境变量,使用全局可用。
1 | ruby复制代码# 把文件存储为xrsync,加上x权限 |
至此,早点干完活,开始愉快的玩耍吧~
本文转载自: 掘金