使用shell脚本,一键启动hadoop中的NameNode和DataNode。分为普通版和装逼版。装逼版较普通版多了很多判断和信息提示,当然主要还是为了我练习shell脚本而写的。

  如果想实现复用,请注意:

    1.将HADOOP_HOME改为自己的hadoop安装路径。

    2.脚本的权限不低于700

  如果复用装逼版在满足上面的条件后,还需要注意

    1.properties和act.sh必须在同一个文件夹中

    2.确保该文件夹以及脚本的权限不低于700

普通版一键启动/关闭/重启NameNode和DataNode

 #!/bin/bash

 #######################################################
#### ####
####精简版的启动,停止,重启 ####
#### ####
####################################################### # hadoop的安装目录以及启动停止命令所在的文件路径
HADOOP_HOME=/bigData/softWare/hadoop
HADOOP_SBIN=${HADOOP_HOME}/sbin # 用于判断输入是否正确的正则
regex='^[ 1-3 ]$'
# 循环判断用户的输入
i=
while [ ${i} -eq ]
do
echo ""
echo -e "启动这个脚本你想干什么:\n\t1).启动Hadoop\n\t2).关闭hadoop\n\t3).重启hadoop"
read -p "输入你的选择:[1,2,3] > " choose
echo ""
if [[ ${choose} =~ ${regex} ]];then
if [ ${choose} -eq ];then
${HADOOP_SBIN}/hadoop-daemon.sh start namenode
${HADOOP_SBIN}/hadoop-daemon.sh start datanode
echo "杨华彬威武!!!"
echo ""
exit
elif [ ${choose} -eq ];then
${HADOOP_SBIN}/hadoop-daemon.sh stop datanode
${HADOOP_SBIN}/hadoop-daemon.sh stop namenode
echo "杨华彬威武!!!"
echo ""
exit
else
${HADOOP_SBIN}/hadoop-daemon.sh stop datanode
${HADOOP_SBIN}/hadoop-daemon.sh stop namenode
${HADOOP_SBIN}/hadoop-daemon.sh start namenode
${HADOOP_SBIN}/hadoop-daemon.sh start datanode
echo "杨华彬威武!!!"
echo ""
exit
fi
#else
# echo "你输入的字符非法,请重新输入!"
fi
done

装逼版一键启动/关闭/重启NameNode和DataNode

properties脚本(用到的变量和函数)

#!/bin/bash

############################################

#本脚本主要用来给调用它的脚本传递参数,方法#

############################################

#这个是启动NameNode和datanode所在的sbin目录,如果安装目录有改动请将以下值改为自己的安装目录的路径
HADOOP_HOME=/bigData/softWare/hadoop
HADOOP_SBIN=${HADOOP_HOME}/sbin # 这个是匹配用户输入的是否正确的正则变量
regex='^[ 1-2 ]$' #启动NameNode,并将原有脚本输出的信息干掉
startNameNode() {
echo "开始启动NameNode"
${HADOOP_SBIN}/hadoop-daemon.sh start namenode >>/dev/null >>"&1"
if [ $? -eq ]
then
echo ""
resultOfDataNode=$(getPIDOfNameNode)
echo "NameNode启动成功,进程号是:$resultOfDataNode"
else
echo ""
echo "NameNode启动失败,请检查原因!"
exit
fi
} #启动datanode,并将原有的信息干掉
startDataNode() {
resultOfDataNode=$(getPIDOfDataNode) # 判断DataNode是否已经启动,启示这一步是多于的,前面已经验证过了。
if [ "${resultOfDataNode}" == "" ]
then
echo ""
echo "正在启动DataNode。"
${HADOOP_SBIN}/hadoop-daemon.sh start datanode >>/dev/null >>'&1'
if [ $? -eq ]
then
echo ""
echo "DataNode启动成功!"
echo ""
echo "情况汇报:"
echo "NameNode启动成功,进程号是:$(getPIDOfNameNode)"
echo "DataNode启动成功,进程号是:$(getPIDOfDataNode)"
echo ""
exit
else
echo ""
echo "DataNode没有启动,请检查原因!!!"
exit
fi
else
echo ""
echo -e "我承认,如果你看到这个信息,不是脚本错误,\n就是发生了他妈的我也不懂的什么错误!"
exit
fi
} # NameNode已经启动的情况下的处理
nameNodeAlreadyStart() {
stopNameNode=
while [ ${stopNameNode} -eq ]
do
echo ""
result=$(getPIDOfNameNode)
echo "NameNode已经启动,进程号是:${result},是否关掉?"
echo -e "\t1).关掉NameNOde并重启。\n\t2).不管,继续启动DataNode."
echo ""
read -p "请输入您的选择:[1/2] > " ifStopNameNode if [[ ${ifStopNameNode} =~ ${regex} ]]
then
if [ ${ifStopNameNode} -eq ]
then
stopNameNode
echo ""
echo "正在启动NameNode"
${HADOOP_SBIN}/hadoop-daemon.sh start namenode >>/dev/null >>'&1'
if [ $? -eq ]
then
result=$(getPIDOfNameNode)
echo ""
echo "NameNode节点启动成功,进程号是:$result"
break
else
echo ""
echo "NameNode启动失败,请检查原因!!!"
exit
fi
else
dataNodeIfStart
fi
else
echo ""
echo "您输入的数字有误,请重新输入!!!"
fi
done
} # DataNode已经启动的情况的处理。
dataNodeAlreadyStart(){
i=
while [ $i -eq ]
do
echo ""
echo -e "DataNode已经启动,请问这种情况该怎么办?:\n\t1).重启DataNode。\n\t2).不重启DataNode"
echo ""
read -p "请输入您的选择:[1/2] > " a
if [[ ${a} =~ ${regex} ]]
then
if [ ${a} -eq ]
then
stopDataNode
startDataNode
exit
else
echo ""
echo "情况汇报:"
echo "NameNode启动成功,进程号是:$(getPIDOfNameNode)"
echo "DataNode启动成功,进程号是:$(getPIDOfDataNode)"
echo ""
exit
fi
fi
done
} #关掉namenode,将信息干掉(完成)
stopNameNode() { result=$(getPIDOfNameNode) if [ "${result}" == "" ]
then
echo ""
echo -e "\033[40;35mNameNode不知道什么原因,已经关闭。请注意检查原因!!!\033[40;35m"
echo -e "\033[40;37m \033[40;37m"
echo "NameNode和DataNode已经关闭!"
echo ""
exit
else
echo "开始停止NameNode"
${HADOOP_SBIN}/hadoop-daemon.sh stop namenode >>/dev/null >>'&1'
if [ $? -eq ]
then
echo ""
echo "NameNode关闭成功!"
echo ""
echo "DataNode和NameNode关闭成功!"
echo ""
exit
else
echo ""
echo "对不起NameNode没有关掉,进程号是:$(getPIDOfNameNode)"
echo "请检查NameNode无法关闭的原因!!!"
echo ""
exit
fi fi } # 关掉datanode,并将信息干掉。(完成)
stopDataNode() {
result=$(getPIDOfDataNode)
if [ "${result}" == "" ]
then
echo ""
echo -e "\033[40;35mDataNode不知道什么原因,已经关闭。请注意检查原因!!!\033[40;35m"
echo -e "\033[40;37m \033[40;37m"
stopNameNode
else
echo ""
echo "正在关闭DataNode"
${HADOOP_SBIN}/hadoop-daemon.sh stop datanode >>/dev/null >>'&1'
if [ $? -eq ]
then
echo ""
echo "DataNode关闭成功!"
else
echo ""
echo "DataNode关闭失败!!!"
echo "请检查失败原因!!!"
exit
fi
fi } # 判断DataNode是否启动
dataNodeIfStart() { resultDataNode=$(getPIDOfDataNode)
if [ "$resultDataNode" != "" ] # 如果DataNode已经启动的话
then
dataNodeAlreadyStart
else
startDataNode
fi
} #获取NameNode的进程号(完成)
getPIDOfNameNode() {
PIDOfNameNode=`jps|grep NameNode|awk '{print $1}'`
echo ${PIDOfNameNode}
} #获取DataNode的进程号(完成)
getPIDOfDataNode() {
PIDOfDataNode=`jps|grep DataNode|awk '{print $1}'`
echo ${PIDOfDataNode}
}

act.sh(脚本的运行)

#!/bin/bash

#######################################################

####启动和停止的脚本都在这个里面,本脚本指调用前面的###
####变量和方法。 ### ####################################################### # 调用前面的properties文件,两个脚本必须放在同一个文件夹中,并分别又有执行权限
source ./properties # 循环判断输入的数字是否合法,是否要执行 i= while [ $i -eq ]
do
# 输出欢迎语句。
echo ""
echo "请问您是要启动hadoop还是要关闭
.)启动hadoop
.)关闭hadoop"
echo ""
read -p "请输入您的选择:[1,2]> " check1
if [[ ${check1} =~ ${regex} ]] # 这一行用来判断输入的是否是1和2这两个数字。
then
if [ ${check1} -eq ] # 如果输入的是启动命令
then
echo ""
resultNameNode=$(getPIDOfNameNode)
if [ "$resultNameNode" != "" ] # 如果NameNode已经启动的话
then
nameNodeAlreadyStart
echo ""
dataNodeIfStart
else # 如果DataNode没有启动的话
startNameNode
dataNodeIfStart
fi
else # 输入的是关闭hadoop的命令
stopDataNode
stopNameNode
a=$(getPIDOfNameNode)
b=$(getPIDOfDataNode)
if [ "${a}" == "" ] && [ "${b}" == "" ]
then
echo ""
echo "NameNode和DataNode关闭成功!"
echo ""
exit
fi
fi
else # 输入的不符合规范
echo ""
echo "输入非法,请重新输入!"
#welcome
fi
done

一键启动NameNode和DataNode--shell脚本的更多相关文章

  1. 一个简单的Linux启动jar包的shell脚本

    背景: 项目设备端需要运行jar包程序与服务端进行socket连接并发送数据,每次启动进程时,都需要在Linux终端输入启动jar包的命令,比较繁琐,随之尝试将启动jar包的命令写入shell脚本文件 ...

  2. Docker - 避免启动container后运行shell脚本执行完成后docker退出container

    问题 最近在使用 Dockerfile 启动容器,发现使用Dockerfile调用容器里面的shell,当shell执行完成以后,docker会退出容器. 分析 Docker 在执行shell的时候, ...

  3. Linux Shell 脚本学习第一天: 使用grep 命令,lsusb, ps -ef, 实现树莓派(Debian OS)时检测到依赖的USB设备启动后,启动终端自动执行shell脚本

    1.应用背景: 无人监测的设备,常需要设置应用程序开机启动,程序启动前需要保证调用的设备先启动,运行环境先启动. 2.test.sh部分源码 #!/bin/sh #查看桌面是否启动 while tru ...

  4. 一键启动frida server的cmd脚本

    和以前写过的在pc直接操作的手机端的sqlite的脚本类似,需要用到重定向的命令 frida-server_helper.bat su /data/local/tmp/frida-server fri ...

  5. 在idea中编写自动拉取、编译、启动springboot项目的shell脚本

    idea 开发环境搭建 idea中安装shell开发插件 服务器具备的条件 已经安装 lsof(用于检查端口占用) 已安装 git 安装 maven 有 java 环境 背景 代码提交到仓库后,需要在 ...

  6. 一个客户端一键安装环境和服务的shell脚本

    #!/bin/bash basepath=$(cd `dirname $0`; pwd)SHELL_DIR="${basepath}/shell"PACKAGE_DIR=" ...

  7. 启动jar包的shell脚本

    在jar包的同级目录新建文件例如:app_jar.sh 然后填写如下内容: #!/bin/bash #source /etc/profile # Auth:Liucx # Please change ...

  8. myaliyun ECS 启动内外穿透工具shell脚本

    #!/bin/bash tbp=/usr/local/ngrok cmd=$1 if [[ -z $cmd ]];then echo "err!usage{sh $0 1|0 to star ...

  9. SpringBoot2.x应用启动、关闭shell脚本

    本篇主要说明以下内容: 1.SpringBoot2.x应用启动.关闭的shell脚本 1 启动脚本 直接放到同jar包同一个目录下,如下: #!/usr/bin/env bash APPLICATIO ...

随机推荐

  1. cocos2d-x屏幕分辨率,窗口大小总结

    这个东西很烦人,相信很多人都不理解 今天来总结一下,首先有很多概念都要事先弄得清楚明白 1.屏幕分辨率 所谓屏幕分辨率相信很多人都知道他的概念,不就是1280pxX720PX吗?不就是这种形式吗?有什 ...

  2. Javascript数值转换(string,int,json)

    数值: 在JavaScript中,数值转换一般有三种方式: 一.Number(param)函数:param可以用于任何数据类型 1.1 param是Boolean值,true和false分别转换为1和 ...

  3. POJ 2387 Til the Cows Come Home(最短路 Dijkstra/spfa)

    传送门 Til the Cows Come Home Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 46727   Acce ...

  4. 12,13 Proxy和Reflect

    Proxy和Reflect Proxy(代理) Proxy用于修改某些操作的默认行为,等同于在语言层面做出修改,所以属于一种"元编程"(meta programming),即对编程 ...

  5. 【gulp】工作中的实战

    写这篇文章的目的是为了以后的项目中懒得再去配gulp,直接可以拿这篇博客中的来用,因为有时候配置还是挺烦人的. gulp相关插件的介绍 用法比较简单,假设大家都会用gulp,下面主要介绍一下一些插件的 ...

  6. href,src,url 整理

    一.href 和 src 的定义及区别 href:Hypertext Reference(超文本引用),指定网络资源的位置,从而在当前元素或者当前文档和由当前属性定义的需要的锚点或资源之间定义一个链接 ...

  7. JVM内存垃圾回收方法

    1.概述 1.1.为什么要回收? 如果不进行垃圾回收,内存迟早都会被消耗空,因为我们在不断地分配内存空间而不进行回收.除非内存无限大,我们可以任性地分配而不回收,但是事实并非如此.所以,垃圾回收是必须 ...

  8. sqlserver 数据库索引建立原则

    1.始终包含聚集索引 当表中不包含聚集索引时,表中的数据是无序的,这会降低数据检索效率.即使通过索引缩小了数据检索的范围,但由于数据本身是无序的,当从表中提取实际数据时,会产生频繁的定位问题,这也使得 ...

  9. MySQL安装与设置

    下载zip,配置 1,系统变量添加:...\mysql-5.7.10-winx64,环境变量添加:%MYSQL_HOME%\bin 2,修改MySQL.ini basedir=(同系统变量路径) da ...

  10. 【Make a H5 game】JS for beginner——FROM U2B

    https://www.youtube.com/watch?v=F2Dc-JlwgN4&feature=iv&src_vid=WfL4LNUL3R0&annotation_id ...