flume启动停止脚本

flume启动停止脚本

1.在bin/目录下创建f1.sh

vim f1.sh

写入

#! /bin/bash

case $1 in
"start")
        for i in hadoop01 hadoop02
        do
            echo"---------启动 $i 采集flume----------"
            ssh $i "nohup /opt/flume/bin/flume-ng agent --conf-file /opt/flume/conf/flume-kafka.conf --name a1 -Dflume.root.logger=INFO,LOGFILE >/opt/flume/log1.txt 2>&1  &"
        done
;;
"stop")
        for i in hadoop01 hadoop02
        do
            echo"---------停止 $i 采集flume----------"
            ssh $i "ps -ef | grep flume-kafka | grep -v grep |awk  '{print \$2}' | xargs -n1 kill -9"
        done
;;
esac

说明

1:nohup,该命令可以在你退出帐户/关闭终端之后继续运行相应的进程。nohup就是不挂起的意思,不挂断地运行命令。

2:awk 默认分隔符为空格

3:$2是在“”双引号内部会被解析为脚本的第二个参数,但是这里面想表达的含义是awk的第二个值,所以需要将他转义,用\$2表示。

4:xargs 表示取出前面命令运行的结果,作为后面命令的输入参数

2.增加脚本执行权限

chmod 777 f1.sh

3.测试脚本

f1.sh start
f1.sh stop

 

posted @ 2022-05-16 19:21  是帅哥没错  阅读(240)  评论(0编辑  收藏  举报