shell脚本一键启动

三台主机名:s1 s2 s3

xcall jps

#!/bin/sh
pcount=$#
if((pcount==0));then
        echo no args...;
        exit;
fi
params=$@
for((host=1; host<=3; host++)); do
        echo ==================s$host==================
        ssh s$host "source /etc/profile;$params"
done

注意,否则会报错“找不到命令”

执行./xcall.sh jps命令,注意需要在/usr/local/bin下添加jps命令的软链接。

ln -s /usr/java/jdk1.8.0_141/bin/jps /usr/local/bin/jps

start-zk.sh

#!/bin/sh
for host in s1 s2 s3
do
ssh $host "source /etc/profile;/usr/zookeeper/zookeeper-3.4.12/bin/zkServer.sh start"
echo "$host zk is running"

done

stop-zk.sh

#!/bin/sh
for host in s1 s2 s3
do
echo "$host zk is stopping"
ssh $host "source /etc/profile;/usr/zookeeper/zookeeper-3.4.12/bin/zkServer.sh stop"

done

start-kafka.sh

#!/bin/bash
 
BROKERS="s1 s2 s3"
 
KAFKA_HOME="/usr/kafka/kafka_2.12-1.1.0"
 
for broker in $BROKERS
 
do
 
        echo "INFO:starting kafka server on ${broker}"
 
        ssh $broker  "source /etc/profile;${KAFKA_HOME}/bin/kafka-server-start.sh -daemon ${KAFKA_HOME}/config/server.properties & "
 
        if [ $? != 0 ];
 
        then
 
                echo "Can not starting kafka server on host ${broker}";
 
                exit 1;
 
        fi
 
done

stop-kafka.sh

#!/bin/sh
KAFKA_HOME="/usr/kafka/kafka_2.12-1.1.0"
BROKERS="s1 s2 s3" 
for broker in $BROKERS
 
do
 
        echo "INFO:stopping kafka server on ${broker}"
 
        ssh $broker "source /etc/profile;${KAFKA_HOME}/bin/kafka-server-stop.sh"
 
        if [ $? != 0 ];
 
        then
 
                echo "Can not stopping kafka server on host ${broker}"
 
                exit 1
 
        fi
 
done

kafka修改bin下的kafka-server-stop.sh文件

PIDS = $(ps ax | grep -i'kafka \ .Kafka'| grep java | grep -v grep | awk'{print $ 1}')

修改后:

PIDS = $(ps ax | grep -i'Kafka'| grep java | grep -v grep | awk'{print $ 1}')

这些脚本要放在在/ usr / local / bin目录下,运行的时候要给脚本赋权限:

chmod + x XXX.sh

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

5t李

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值