大数据之Linux部署常用命令脚本封装

文章目录

    • 编写集群命令执行脚本
      • xcall集群命令执行
        • [1. 脚本需求](#1. 脚本需求)
        • [2. 需求分析](#2. 需求分析)
        • [3. 脚本实现](#3. 脚本实现)
          • [3.1 创建脚本存放目录](#3.1 创建脚本存放目录)
          • [3.2 编写xcall脚本](#3.2 编写xcall脚本)
          • [3.3 修改脚本执行权限](#3.3 修改脚本执行权限)
          • [3.4 测试脚本](#3.4 测试脚本)
    • 编写集群分发脚本
      • xsync集群分发脚本
        • [1. 脚本需求](#1. 脚本需求)
        • [2. 需求分析](#2. 需求分析)
        • [3. 脚本实现](#3. 脚本实现)
          • [3.1 创建脚本存放目录](#3.1 创建脚本存放目录)
          • [3.2 编写xsync脚本](#3.2 编写xsync脚本)
          • [3.3 修改脚本执行权限](#3.3 修改脚本执行权限)
          • [3.4 测试脚本](#3.4 测试脚本)

编写集群命令执行脚本

xcall集群命令执行

1. 脚本需求
  • 需求: 简化对多个远程主机执行相同命令的过程。允许用户通过一个单一的命令行调用,在一组预定义的主机上执行任意命令。方便集群管理和自动化任务,减少重复工作并提高效率。
2. 需求分析
  • 使用xcall 命令进行命令执行, 例如

    sh 复制代码
    xcall ls -al /
  • 期望脚本xcall 能够在所有预定义的主机上查看根目录/ 的内容。

3. 脚本实现
  • 脚本存放在/home/bigdata/bin目录下,在~/.bashrc中添加以下内容,以便bigdata用户可以在系统的任何位置直接执行。

    sh 复制代码
    export PATH=$PATH:/home/bigdata/bin
  • 使环境变量生效 source ~/.bashrc

3.1 创建脚本存放目录
  • /home/bigdata目录下创建bin文件夹:

    sh 复制代码
    mkdir bin
  • 脚本存放在/home/bigdata/bin目录下,以便bigdata用户可以在系统的任何位置直接执行。

3.2 编写xcall脚本
  • /home/bigdata/bin目录下创建xall文件:

    sh 复制代码
    cd /home/bigdata/bin
    vim xcall
  • 编写脚本内容:

    bash 复制代码
    #!/bin/bash
    # 定义主机名数组
    hosts=("hadoop101" "hadoop102" "hadoop103")
    # 检查是否有外部参数传递给脚本
    if [ $# -eq 0 ]; then
        echo "Usage: $0 <command>"
        exit 1
    fi
     # 遍历主机数组,对每个主机执行 SSH 命令
    for host in "${hosts[@]}"; do
        echo "-------- $host --------"
        ssh "$host" "$*"
    done
3.3 修改脚本执行权限
  • 使xcall脚本具有执行权限:

    sh 复制代码
    chmod +x xcall
3.4 测试脚本
  • 测试xcall脚本是否正常工作:

    sh 复制代码
    xcall ls -al /

编写集群分发脚本

xsync集群分发脚本

1. 脚本需求
  • 需求:实现循环复制文件到所有节点的相同目录下。
2. 需求分析
  • 使用rsync命令进行原始拷贝,例如:

    sh 复制代码
    rsync -av /opt/module bigdata@hadoop102:/opt/
  • 期望脚本xsync能够同步指定的文件名称。

3. 脚本实现
  • 脚本存放在/home/bigdata/bin目录下,以便bigdata用户可以在系统的任何位置直接执行。
3.1 创建脚本存放目录
  • /home/bigdata目录下创建bin文件夹:

    sh 复制代码
    mkdir bin
3.2 编写xsync脚本
  • /home/bigdata/bin目录下创建xsync文件:

    sh 复制代码
    cd /home/bigdata/bin
    vim xsync
  • 编写脚本内容:

    bash 复制代码
    #!/bin/bash
    
    hosts=("hadoop101" "hadoop102" "hadoop103")
    # 1. 判断参数个数
    if [ $# -lt 1 ]
    then
      echo "Not Enough Arguments!"
      exit 1
    fi
    
    # 2. 遍历集群所有机器
    for host in "${hosts[@]}"; 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 exist!"
        fi
      done
    done
3.3 修改脚本执行权限
  • 使xsync脚本具有执行权限:

    sh 复制代码
    chmod +x xsync
3.4 测试脚本
  • 测试xsync脚本是否正常工作:

    sh 复制代码
    xsync /path/to/file_or_directory
相关推荐
东哥说-MES|从入门到精通24 分钟前
Mazak MTF 2025制造未来参观总结
大数据·网络·人工智能·制造·智能制造·数字化
盟接之桥29 分钟前
盟接之桥说制造:在安全、确定与及时之间,构建品质、交期与反应速度的动态平衡
大数据·运维·安全·汽车·制造·devops
learning_tom42 分钟前
HTML图片标签及路径详解
linux·服务器·php
链上日记1 小时前
STC携手VEX发起全球首个碳资产RWA生态,泰国峰会即将引爆绿色金融
大数据
dbdr09011 小时前
Linux 入门到精通,真的不用背命令!零基础小白靠「场景化学习法」,3 个月拿下运维 offer,第二十六天
linux·运维·服务器·网络·python·学习
用户Taobaoapi20142 小时前
京东商品列表API(JD.item_search)
大数据·数据挖掘·数据分析
大白的编程日记.2 小时前
【Linux学习笔记】信号的深入理解之软件条件产生信号
linux·笔记·学习
鹧鸪云光伏与储能软件开发2 小时前
投资储能项目能赚多少钱?小程序帮你测算
运维·数据库·小程序·光伏·光伏设计软件·光伏设计
群联云防护小杜2 小时前
服务器异常磁盘写排查手册 · 已删除文件句柄篇
运维·服务器·nginx·开源·lua
buyutang_2 小时前
C/C++ Linux系统编程:线程控制详解,从线程创建到线程终止
linux·c语言·c++·学习