服务器之家:专注于服务器技术及软件下载分享
分类导航

Linux|Centos|Ubuntu|系统进程|Fedora|注册表|Bios|Solaris|Windows7|Windows10|Windows11|windows server|

香港云服务器
服务器之家 - 服务器系统 - Linux - Linux文件分发脚本:只需一条命令将你的文件分发到各个服务器上

Linux文件分发脚本:只需一条命令将你的文件分发到各个服务器上

2021-12-01 23:17今日头条运维贼船 Linux

在运维或在日常工作生活中,我们经常会把一个文件拷贝到其它服务器上,或同时分发到多个服务器上,甚至要求目标机将文件放在相同的路径下,方便程序进一步调用。

背景

在运维或在日常工作生活中,我们经常会把一个文件拷贝到其它服务器上,或同时分发到多个服务器上,甚至要求目标机将文件放在相同的路径下,方便程序进一步调用。

Linux文件分发脚本:只需一条命令将你的文件分发到各个服务器上

遇到这种问题,我们通常的做法是使用scp或rsync命令把文件拷贝一个一个地拷贝到多台服务器上,这样做费事费力;大神的做法是使用ansible的playbook一下把事情干完,前提是你得会ansible;快捷的做法就是使用今天的脚本了。

效果演示

目前拥有4台机器,分别为client、node1、node2和node3,client与其它3台机器能够建立ssh链接。在client的/root/test目录下有a.txt和b.txt两个文件。

Linux文件分发脚本:只需一条命令将你的文件分发到各个服务器上
  1. [root@client test]# ls /root/test/
  2. a.txt b.txt
  3. [root@client test]#

我把文件分发到node1、node2和node3的/root/test下,执行以下命令:

  1. # 在/root/test目录下执行, xrsync是我的脚本
  2. [root@client test]# xrsync a.txt b.txt

执行分发过程:

  1. [root@client test]# xrsync a.txt b.txt
  2. ============ node1 ============
  3. sending incremental file list
  4. a.txt
  5. sent 93 bytes received 35 bytes 256.00 bytes/sec
  6. total size is 2 speedup is 0.02
  7. sending incremental file list
  8. b.txt
  9. sent 93 bytes received 35 bytes 85.33 bytes/sec
  10. total size is 2 speedup is 0.02
  11. ============ node2 ============
  12. sending incremental file list
  13. a.txt
  14. sent 93 bytes received 35 bytes 256.00 bytes/sec
  15. total size is 2 speedup is 0.02
  16. sending incremental file list
  17. b.txt
  18. sent 93 bytes received 35 bytes 256.00 bytes/sec
  19. total size is 2 speedup is 0.02
  20. ============ node3 ============
  21. sending incremental file list
  22. a.txt
  23. sent 93 bytes received 35 bytes 85.33 bytes/sec
  24. total size is 2 speedup is 0.02
  25. sending incremental file list
  26. b.txt
  27. sent 93 bytes received 35 bytes 256.00 bytes/sec
  28. total size is 2 spee

到node2上看一下,文件果然存在。同样地,node3和node4也同步过去了。

  1. # node2上查看
  2. [root@node2 ~]# ls /root/test/
  3. a.txt b.txt
  4. [root@node2 ~]#
  5. # node3上查看
  6. [root@node3 ~]# ls /root/test/
  7. a.txt b.txt
  8. [root@node3 ~]#
  9. # node4上查看
  10. [root@node4 ~]# ls /root/test/
  11. a.txt b.txt
  12. [root@node4 ~]#

脚本奉上

整个脚本的代码,只需要把其中的node1 node2 node3修改为自己环境下的主机名或ip地址即可。

  1. #!/bin/bash
  2. # 判断参数是否足够
  3. if [ $# -lt 1 ]
  4. then
  5. echo Not Enounh Arguement!
  6. exit;
  7. fi
  8. # 遍历所有的机器
  9. for host in node1 node2 node3
  10. do
  11. echo ============ $host ============
  12. for file in $@
  13. do
  14. # 判断文件是否存在
  15. if [ -e $file ]
  16. then
  17. # 获取父目录
  18. pdir=$(cd -P $(dirname $file); pwd)
  19. # 获取当前目录的名称
  20. fname=$(basename $file)
  21. ssh $host "mkdir -p $pdir"
  22. rsync -av $pdir/$fname $host:$pdir
  23. else
  24. echo $file does not exists!
  25. fi
  26. done
  27. done

运行条件

为了更方便脚本的运行,建议使用如下优化。

1.修改/etc/hosts文件,加入IP地址与主机名的对应关系,这样方便我们使用主机名直接操作。比如我演示的机器配置。

  1. vim /etc/hosts
  2. # 加入配置,自己的机器对应修改
  3. ……
  4. 192.168.31.47 client
  5. 192.168.31.48 node1
  6. 192.168.31.50 node2
  7. 192.168.31.51 node3

2.客户机与目标机之间使用ssh密码验证登录,这样在传输文件时不需要二次验证。

  1. # 生成ssh私钥
  2. ssh-keygen -f /root/.ssh/id_rsa -N ''
  3. # 循环把公钥传递到服务器上,免密登录
  4. for i in node1 node2 node3
  5. do
  6. ssh-copy-id $i
  7. done
  8. # 根据提示输入密码

3.给脚本加可执行权限,并配置环境变量,使用全局可用。

  1. # 把文件存储为xrsync,加上x权限
  2. [root@client shell]# chmod +x xrsync
  3. [root@client shell]#
  4. # 配置环境变量
  5. # 我把脚本放在/opt/shell下的,自己情况类比修改
  6. [root@client shell]# vim /etc/profile.d/my_env.sh
  7. export PATH=$PATH:/opt/shell
  8. # 配置生效,就可以在全局生效了
  9. [root@client opt]# source /etc/profile

原文链接:https://www.toutiao.com/a7035070177486520865/

延伸 · 阅读

精彩推荐
756