设为首页 收藏本站
查看: 842|回复: 0

[经验分享] hadoop一键安装伪分布式

[复制链接]

尚未签到

发表于 2017-12-17 16:32:12 | 显示全部楼层 |阅读模式
#!/bin/bash  

  
source ./install-env.sh
  

  
# 创建文件夹,并清空文件夹
  
function creatFile(){
  
     if [ -e $1 ]
  
     then
  
         echo "文件夹已经存在!将清空${1}!!!\n"
  
         isContinue "清空${1}" "将要清空${1}"
  
         rm -rf ${1}/*
  
         isSuccess $? "${1}清空成功,准备解压文件。" "${1}清空失败,请检查原因!!!"
  
     else
  
         mkdir ${1}
  
         isSuccess $? "${1}创建成功,准备解压文件。" "${1}创建失败,请检查原因!!!"
  
     fi
  
}
  

  
# 询问是否继续进项操作
  
function isContinue(){
  
     echo -e "\e[1;31m是否${1}【y/n】\e[0m"
  
     read choose
  
     if [ "${choose}" = "y" ] || [ "${choose}" = "yes" ] || [ "${choose}" = "Y" ] || [ "${choose}" = "YES" ]
  
     then
  
         echo -e "\e[1;31m${1}\e[0m"
  
     else
  
         exit
  
     fi
  
}
  

  
# 判断前一个操作是否成功,如果错误就全部推倒重来
  
function isSuccess(){
  
     if [ $1 -eq 0 ]
  
     then
  
         echo "${2}"
  
     else
  
         echo -e "\e[1;31m${3}\e[0m"
  
         rm -rf ${INSTALL_PATH}
  
         exit
  
     fi
  
}
  

  
# 解压缩文件
  
function myTar(){
  
     filePath=`find ../software -name ${1}* | awk -F "/" '{print $NF}'`
  
     tar -zxvf ../software/${filePath} -C ${2} 1>>/dev/null 2>>/dev/null
  
     isSuccess $? "${1}解压成功。" "${2}解压失败,请查找原因!!!"
  
}
  

  
# 修改hadoop的非xml类的配置文件
  
function notXMLHadoop(){
  
     filePath=`ls ${1} | grep hadoop`
  
     mkdir ${HADOOP_TMP_DIR}/myPID
  

  
     for i in ${myArray[@]}
  
     do
  
         sed -i '/export JAVA_HOME=$/d' ${1}/${filePath}${2}/${i}
  
         #sed -i "/export JAVA_HOME=${MY_JAVA_HOME}/d" ${1}/${filePath}${2}/${i}
  
         sed -i "3a export JAVA_HOME=${MY_JAVA_HOME}" ${1}/${filePath}${2}/${i}
  
         isSuccess $? "$i修改成功" "$i修改失败"
  
         
  
     done
  

  
     # 修改各个env.sh文件,修改pid文件存放的路径
  

  
     sed -i "s@export HADOOP_PID_DIR=.*@HADOOP_PID_DIR=${HADOOP_TMP_DIR}/myPID@g" ${1}/${filePath}${2}/hadoop-env.sh
  
     
  
#    sed -i "/export HADOOP_MAPRED_PID_DIR=${HADOOP_TMP_DIR}\/myPID/d" ${1}/${filePath}${2}/mapred-env.sh
  
     sed -i "4a export HADOOP_MAPRED_PID_DIR=${HADOOP_TMP_DIR}/myPID" ${1}/${filePath}${2}/mapred-env.sh
  

  
#    sed -i "/export YARN_PID_DIR=${HADOOP_TMP_DIR}\/myPID/d" ${1}/${filePath}${2}/yarn-env.sh     
  
     sed -i "4a export YARN_PID_DIR=${HADOOP_TMP_DIR}/myPID" ${1}/${filePath}${2}/yarn-env.sh
  

  
     # 修改slaves文件
  
     sed -i "1a `hostname`" ${1}/${filePath}${2}/slaves
  
     isSuccess $? "slaves修改成功" "slaves修改失败"
  
     sed -i '1d' ${1}/${filePath}${2}/slaves
  
}
  

  
# 修改hadoop中的xml类的配置文件

  
function>  

  
     myArray=($@)
  
     filePath=`ls ${INSTALL_PATH} | grep hadoop`
  
     for ((i=1;i<${#myArray[@]};i+=2))
  
     do
  
         j=$((i+1))
  
         java -jar ../lib/JavaStudy.jar /${INSTALL_PATH}/${filePath}${HADOOP_PROFILEPATH}/${myArray[0]} add ${myArray[$i]} ${myArray[$j]}
  
         isSuccess $? "${myArray[0]}中的${myArray[$i]}修改成功" "${myArray[0]}中的${myArray[$i]}修改失败,请检查原因!!!"
  
     done
  
}
  

  
# 修改当前用户的.bashrc文件,添加hadoop中pid等配置的存放路径

  
function>  
     bashrcPathe=~/.bashrc
  
     mkdir ${HADOOP_TMP_DIR}/myPID
  
     sed -i "/myPIDDir=/d" ${bashrcPathe}
  
     sed -i "\$a myPIDDir=${HADOOP_TMP_DIR}/myPID" ${bashrcPathe}
  
     sed -i "/export HADOOP_PID_DIR=${myPIDDir}/d" ${bashrcPathe}
  
     sed -i '$a export HADOOP_PID_DIR=${myPIDDir}' ${bashrcPathe}
  
     sed -i '/export YARN_PID_DIR=${myPIDDir}/d' ${bashrcPathe}
  
     sed -i '$a export YARN_PID_DIR=${myPIDDir}' ${bashrcPathe}
  
     sed -i '/export HADOOP_MAPRED_PID_DIR=${myPIDDir}/d' ${bashrcPathe}
  
     sed -i '$a export HADOOP_MAPRED_PID_DIR=${myPIDDir}' ${bashrcPathe}
  
     sed -i '/export HBASE_PID_DIR=${myPIDDir}/d' ${bashrcPathe}
  
     sed -i '$a export HBASE_PID_DIR=${myPIDDir}' ${bashrcPathe}
  

  
     source ~/.bashrc
  
}
  

  
# 格式化NameNode
  
function formatNameNode(){
  
     filePath=`ls ${INSTALL_PATH} | grep hadoop`
  
     ${INSTALL_PATH}/${filePath}/bin/hdfs namenode -format 1>>/dev/null 2>>/dev/null
  
     if [ $? -ne 0 ]
  
     then
  
         exit
  
     fi
  
     isSuccess $? "NameNode格式化成功!" "NameNode格式化失败,请查找原因!!!"
  
}
  

  
# 配置好hive的配置文件
  
function setHiveNotXML(){
  
     echo "开始修改hive的非xml配置文件"
  
     filePath=`ls ${INSTALL_PATH} | grep hive`
  
     cp ${INSTALL_PATH}/${filePath}/conf/hive-env.sh.template ${INSTALL_PATH}/${filePath}/conf/hive-env.sh
  
     cp ${INSTALL_PATH}/${filePath}/conf/hive-exec-log4j.properties.template ${INSTALL_PATH}/${filePath}/conf/hive-exec-log4j.properties
  
     cp ${INSTALL_PATH}/${filePath}/conf/hive-log4j.properties.template ${INSTALL_PATH}/${filePath}/conf/hive-log4j.properties
  
     touch  ${INSTALL_PATH}/${filePath}/conf/hive-site.xml
  
     echo '<?xml version="1.0" encoding="UTF-8" standalone="no"?>' > ${INSTALL_PATH}/${filePath}/conf/hive-site.xml
  
     sed -i '1a <?xml-stylesheet type="text/xsl" href="configuration.xsl"?>' ${INSTALL_PATH}/${filePath}/conf/hive-site.xml
  
     sed -i '2a <configuration>' ${INSTALL_PATH}/${filePath}/conf/hive-site.xml
  
     sed -i '3a </configuration>' ${INSTALL_PATH}/${filePath}/conf/hive-site.xml   
  
     # 修改hive-env.sh
  
     hadoopPath=`ls ${INSTALL_PATH} | grep hadoop`
  
     sed -i "\$a HADOOP_HOME=${INSTALL_PATH}/${hadoopPath}" ${INSTALL_PATH}/${filePath}/conf/hive-env.sh
  
     sed -i "\$a HIVE_CONF_DIR=${INSTALL_PATH}/${filePath}/conf" ${INSTALL_PATH}/${filePath}/conf/hive-env.sh
  
     sed -i "\$a export JAVA_HOME=${MY_JAVA_HOME}" ${INSTALL_PATH}/${filePath}/conf/hive-env.sh
  
     
  
     # 修改hive-log4j.properties文件
  
     mkdir ${hiveLogs}
  
     sed -i "s@hive.log.dir=.*@hive.log.dir=${hiveLogs}@g" ${INSTALL_PATH}/${filePath}/conf/hive-log4j.properties
  
}
  

  
# 修改hive的xml文件

  
function>  
     myArray=($@)
  
     filePath=`ls ${INSTALL_PATH} | grep hive`
  
     for ((i=1;i<${#myArray[@]};i+=2))
  
     do
  
         j=$((i+1))
  
         java -jar ../lib/JavaStudy.jar /${INSTALL_PATH}/${filePath}/conf/${myArray[0]} add ${myArray[$i]} ${myArray[$j]}
  
         isSuccess $? "${myArray[0]}中的${myArray[$i]}修改成功" "${myArray[0]}中的${myArray[$i]}修改失败,请检查原因!!!"
  
     done   
  
}
  

  
# 创建hive的配置文件夹,并Java的mysql驱动jar包复制到hive中的lib文件夹中
  
function hiveOver(){
  
     mkdir ${HIVE_TMP_DIR}
  
     filePath=`ls ${INSTALL_PATH} | grep hive`
  
     cp ../lib/${mysqlConnetor} ${INSTALL_PATH}/${filePath}/lib
  
     isSuccess $? "hadoop与hive的伪分布式安装成功,just have fun!" "复制mysql的jar包失败,请检查原因!!!"
  
}

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-425057-1-1.html 上篇帖子: 利用docker搭建spark hadoop workbench 下篇帖子: 马士兵hadoop第五课:java开发Map/Reduce
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表