发布于2021-05-29 21:11 阅读(592) 评论(0) 点赞(2) 收藏(4)
UI界面基于 layui - layout 构建
新建表:
查看详情:
添加/更新/修改 数据:
删除列族:
删除行键:
删除表:
本机所需环境:
- java
- scala
- mysql
- maven
在三台虚拟机的/etc/profile
中添加:
export JAVA_HOME=/opt/modules/jdk1.8.0_161
export PATH=$PATH:$JAVA_HOME/bin
export HADOOP_HOME=/opt/modules/hadoop-2.8.2
export PATH=$PATH:$HADOOP_HOME/bin:$HADOOP_HOME/sbin
export ZOOKEEPER_HOME=/opt/modules/zookeeper-3.4.10
export PATH=$PATH:$ZOOKEEPER_HOME/bin
export HBASE_HOME=/opt/modules/hbase-1.2.6.1
export PATH=$PATH:$HBASE_HOME/bin
export HIVE_HOME=/opt/modules/apache-hive-2.3.8-bin
export PATH=$PATH:$HIVE_HOME/bin
export SQOOP_HOME=/opt/modules/sqoop-1.4.7
export PATH=$PATH:$SQOOP_HOME/bin
export FLUME_HOME=/opt/modules/apache-flume-1.8.0-bin
export PATH=$PATH:$FLUME_HOME/bin
export KAFKA_HOME=/opt/modules/kafka_2.11-2.0.0
export PATH=$PATH:$KAFKA_HOME/bin
export KAFKA_CONFIG_HOME=/opt/modules/kafka_2.11-2.0.0/config
export PATH=$PATH:$KAFKA_CONFIG_HOME/bin
export STORM_HOME=/opt/modules/apache-storm-1.1.0
export PATH=$PATH:$STORM_HOME/bin
export ELASTICSEARCH_HOME=/opt/modules/elasticsearch-7.12.0
export PATH=$PATH:$ELASTICSEARCH_HOME/bin
export KIBANA_HOME=/opt/modules/kibana-7.12.0-linux-x86_64
export PATH=$PATH:$KIBANA_HOME/bin
export ELASTICSEARCH_HEAD_HOME=/opt/modules/node-v10.9.0-linux-x64
export PATH=$PATH:$ELASTICSEARCH_HEAD_HOME/bin
集群启动脚本start-cluster.sh
:
#! /bin/bash
function help() {
echo -e "\033[32;1m
start_cluster.sh默认会启动 Zookeeper ,其余的Hadoop组件则需要手动在命令行后面添加参数启动
例如:
启动 YARN HA :start_cluster.sh yarn
启动 YARN HA 和 HBase HA :start_cluster.sh yarn hbase
...
可选Hadoop组件参数有:
hdfs -- 启动 HDFS HA --
yarn -- 启动 YARN HA |
hbase -- 启动 HBase HA |
hive -- 启动 Hive > 经过实测,这些组件可以同时启动
spark -- 启动 Spark |
kafka -- 启动 Kafka |
storm -- 启动 Storm --
* * * * * * * * *
elasticsearch -- 启动 elasticsearch --
kibana -- elasticsearch 是必填项 > 这三个组件可以同时启动
elasticsearch_head -- elasticsearch 是必填项 --
* * * * * * * * *
all -- 一键启动全部组件 !!!慎用
关于flume:本脚本不提供flume的一键启动,请使用命令
-- flume-ng agent --conf c0nf --conf-file $FLUME_HOME/conf/flume-conf.properties --name a1 -Dflume.root.logger=INFO,console
来启动flume监听44444端口,通过ssh远程登陆centos01,使用【telnet localhost 44444】命令来测试flume
\033[0m \033[33;1m
一则警告 WARNING ;
上面的这些组件如果想要全部同时启动,即执行
-- start_cluster.sh yarn hbase hive spark kafka storm elasticsearch kibana elasticserch_head
或
-- start_cluster.sh all
命令,请确保你的虚拟机集群每台都至少有 6GB 的运行内存,否则后面的几个组件是起不来的,尤其是 elasticsearch 及其扩展组件
极端情况下可能会导致虚拟机卡死甚至外部主机也直接卡死!!!\033[0m
"
}
function start_zookeeper(){
echo -e "\033[32;1m
/****************************************************************/
/* 启动 ZooKeeper 集群 */
/****************************************************************/\033[0m"
ssh -t hadoop@centos01 << remotessh
zkServer.sh start
exit
remotessh
ssh -t hadoop@centos02 << remotessh
zkServer.sh start
exit
remotessh
ssh -t hadoop@centos03 << remotessh
zkServer.sh start
exit
remotessh
}
function start_zkfc(){
echo -e "\033[32;1m
/****************************************************************/
/* 启动 ZKFC 守护进程 */
/****************************************************************/\033[0m"
ssh -t hadoop@centos01 << remotessh
hadoop-daemon.sh start zkfc
exit
remotessh
ssh -t hadoop@centos02 << remotessh
hadoop-daemon.sh start zkfc
exit
remotessh
}
function start_hdfs(){
echo -e "\033[32;1m
/****************************************************************/
/* 启动 HDFS HA */
/****************************************************************/\033[0m"
ssh -t hadoop@centos01 << remotessh
start-dfs.sh
exit
remotessh
}
function start_hdfs_ha(){
start_hdfs
start_zkfc
}
function start_yarn_ha(){
echo -e "\033[32;1m
/****************************************************************/
/* 启动 YARN HA */
/****************************************************************/\033[0m"
ssh -t hadoop@centos01 << remotessh
start-yarn.sh
exit
remotessh
ssh -t hadoop@centos02 << remotessh
yarn-daemon.sh start resourcemanager
exit
remotessh
}
function start_hbase_ha(){
echo -e "\033[32;1m
/****************************************************************/
/* 启动 HBase HA */
/****************************************************************/\033[0m"
ssh -t hadoop@centos01 << remotessh
start-hbase.sh
exit
remotessh
}
function start_hive(){
echo -e "\033[32;1m
/****************************************************************/
/* 启动 Hive */
/****************************************************************/\033[0m"
ssh -t hadoop@centos01 << remotessh
hive --service metastore &
sleep 10
exit
remotessh
}
function start_spark_ha(){
echo -e "\033[32;1m
/****************************************************************/
/* 启动 Spark HA */
/****************************************************************/\033[0m"
ssh -t hadoop@centos01 << remotessh
/opt/modules/spark-2.4.0-bin-hadoop2.7/sbin/start-all.sh
exit
remotessh
ssh -t hadoop@centos02 << remotessh
/opt/modules/spark-2.4.0-bin-hadoop2.7/sbin/start-all.sh
exit
remotessh
}
function start_kafka(){
echo -e "\033[32;1m
/****************************************************************/
/* 启动 Kafka */
/****************************************************************/\033[0m"
ssh -t hadoop@centos01 << remotessh
/opt/modules/kafka_2.11-2.0.0/bin/kafka-server-start.sh -daemon /opt/modules/kafka_2.11-2.0.0/config/server.properties
exit
remotessh
ssh -t hadoop@centos02 << remotessh
/opt/modules/kafka_2.11-2.0.0/bin/kafka-server-start.sh -daemon /opt/modules/kafka_2.11-2.0.0/config/server.properties
exit
remotessh
ssh -t hadoop@centos03 << remotessh
/opt/modules/kafka_2.11-2.0.0/bin/kafka-server-start.sh -daemon /opt/modules/kafka_2.11-2.0.0/config/server.properties
exit
remotessh
}
function start_storm(){
echo -e "\033[32;1m
/****************************************************************/
/* 启动 Storm */
/****************************************************************/\033[0m"
ssh -t hadoop@centos01 << remotessh
storm nimbus >/dev/null 2>&1 &
storm ui >/dev/null 2>&1 &
exit
remotessh
ssh -t hadoop@centos02 << remotessh
storm supervisor >/dev/null 2>&1 &
exit
remotessh
ssh -t hadoop@centos03 << remotessh
storm supervisor >/dev/null 2>&1 &
exit
remotessh
}
function start_elasticsearch(){
echo -e "\033[32;1m
/****************************************************************/
/* 启动 Elasticsearch */
/****************************************************************/\033[0m"
ssh -tt hadoop@centos01 << remotessh
elasticsearch -d
sleep 30
exit
remotessh
}
function start_kibana(){
echo -e "\033[32;1m
/****************************************************************/
/* 启动 Kibana */
/****************************************************************/\033[0m"
ssh -tt hadoop@centos01 << remotessh
kibana &
sleep 30
exit
remotessh
}
function start_elasticsearch_head(){
echo -e "\033[32;1m
/****************************************************************/
/* 启动 Elasticsearch Head */
/****************************************************************/\033[0m"
ssh -tt hadoop@centos01 << remotessh
cd /opt/modules/elasticsearch-head-master
grunt server &
sleep 30
exit
remotessh
}
function in_hadoop(){
echo "${hadoop[@]}" | grep -wq $1 && return 0 || return 1
}
function elasticsearch_in_use(){
echo "${use[@]}" | grep -wq "elasticsearch" && return 0 || return 1
}
hadoop=(all hdfs yarn hbase hive spark kafka storm elasticsearch kibana elasticsearch_head)
use=()
if [[ $# == 0 ]]
then
help
echo -e "\033[34;1m目前你的 start_cluster.sh 后面并没有携带任何参数,请问你是否只打算启动一个 Zookeeper ? [Y/n] \033[0m \c"
read -r -p "" input
case $input in
[yY][eE][sS]|[yY])
start_zookeeper
;;
[nN][oO]|[nN])
exit 1
;;
*)
exit 1
;;
esac
else
if [[ "$1" == "-h" || "$1" == "--h" || "$1" == "-H" || "$1" == "--H" || "$1" == "-help" || "$1" == "--help" ]]
then
help
exit 1
fi
for i in $*
do
in_hadoop $i
if [ $? -eq 1 ]
then
echo -e "\033[31;1m未知参数 【 $i 】 ,请重新输入 \033[0m"
help
exit 1
else
use+=($i)
fi
done
for i in ${use[@]}
do
if [ $i == "all" ]
then
echo -e "\033[33;1m参数中包含【all】,这将会启动所有Hadoop组件,这样做会给虚拟机以及外部本机造成很大的压力,并且有可能造成难以预料的后果;请确认你要这么做: [Y/n] \033[0m \c"
read -r -p "" confrim_all
case $confrim_all in
[yY][eE][sS]|[yY])
echo -e "\033[32;1m
/****************************************************************/
/* 启动全部组件 */
/****************************************************************/\033[0m"
start_zookeeper
start_hdfs_ha
start_yarn_ha
start_hbase_ha
start_hive
start_spark_ha
start_kafka
start_storm
start_elasticsearch
start_kibana
start_elasticsearch_head
exit 1
;;
[nN][oO]|[nN])
exit 1
;;
*)
exit 1
;;
esac
fi
if [ $i == "kibana" ]
then
elasticsearch_in_use
if [ $? -eq 1 ]
then
echo -e "\033[33;1mKibana的启动依赖于elasticsearch,如若想要启动kibana,请将【elasticsearch】添加到参数列表【kibana】之前或去掉【kibana】\033[0m"
exit 1
fi
fi
if [ $i == "elasticsearch_head" ]
then
elasticsearch_in_use
if [ $? -eq 1 ]
then
echo -e "\033[33;1mElasticsearch Head的启动依赖于elasticsearch,如若想要启动kibana,请将【elasticsearch】添加到参数列表【elasticsearch_head】之前或去掉【elasticsearch_head】\033[0m"
exit 1
fi
fi
done
fi
start_zookeeper
for i in ${use[@]}
do
if [ $i == "hdfs" ]
then
start_hdfs_ha
fi
if [ $i == "yarn" ]
then
start_yarn_ha
fi
if [ $i == "hbase" ]
then
start_hbase_ha
fi
if [ $i == "hive" ]
then
start_hive
fi
if [ $i == "spark" ]
then
start_spark_ha
fi
if [ $i == "kafka" ]
then
start_kafka
fi
if [ $i == "storm" ]
then
start_storm
fi
if [ $i == "elasticsearch" ]
then
start_elasticsearch
fi
if [ $i == "kibana" ]
then
start_kibana
fi
if [ $i == "elasticsearch_head" ]
then
start_elasticsearch_head
fi
done
集群关闭脚本stop-cluster.sh
:
ssh hadoop@centos01 << remotessh
stop-hbase.sh
/opt/modules/kafka_2.11-2.0.0/bin/kafka-server-stop.sh
/opt/modules/spark-2.4.0-bin-hadoop2.7/sbin/stop-all.sh
stop-yarn.sh
hadoop-daemon.sh stop zkfc
stop-dfs.sh
zkServer.sh stop
exit
remotessh
ssh hadoop@centos02 << remotessh
/opt/modules/kafka_2.11-2.0.0/bin/kafka-server-stop.sh
yarn-daemon.sh stop resourcemanager
/opt/modules/spark-2.4.0-bin-hadoop2.7/sbin/stop-all.sh
hadoop-daemon.sh stop zkfc
zkServer.sh stop
exit
remotessh
ssh hadoop@centos03 << remotessh
/opt/modules/kafka_2.11-2.0.0/bin/kafka-server-stop.sh
zkServer.sh stop
exit
remotessh
ssh hadoop@centos01 << remotessh
pkill -f HMaster
pkill -f HRegionServer
pkill -f Kafka
pkill -f Worker
pkill -f Master
pkill -f NodeManager
pkill -f ResourceManager
pkill -f RunJar
pkill -f DFSZKFailoverController
pkill -f DataNode
pkill -f NameNode
pkill -f JournalNode
pkill -f QuorumPeerMain
pkill -f nimbus
pkill -f core
pkill -f node
pkill -f Elasticsearch
pkill -f grunt
exit
remotessh
ssh hadoop@centos02 << remotessh
pkill -f HMaster
pkill -f HRegionServer
pkill -f Kafka
pkill -f Worker
pkill -f Master
pkill -f NodeManager
pkill -f ResourceManager
pkill -f RunJar
pkill -f DFSZKFailoverController
pkill -f DataNode
pkill -f NameNode
pkill -f JournalNode
pkill -f QuorumPeerMain
exit
remotessh
ssh hadoop@centos03 << remotessh
pkill -f HMaster
pkill -f HRegionServer
pkill -f Kafka
pkill -f Worker
pkill -f Master
pkill -f NodeManager
pkill -f ResourceManager
pkill -f RunJar
pkill -f DFSZKFailoverController
pkill -f DataNode
pkill -f NameNode
pkill -f JournalNode
pkill -f QuorumPeerMain
exit
remotessh
通过-h
参数来获取集群启动信息:
Hadoop组件可选,默认只启动一个ZooKeeper
上面的UI中的”一键启动集群”由于内存限制,并没有启动Elasticsearch及其附带组件,启动的是hdfs、yarn、hbase、hive、spark、kafka、storm;并且其实UI界面也并没有用到这么多功能,只用到了hdfs、hbase、kafka、spark而已,即执行了:
./start-cluster.sh hdfs kafka hbase yarn spark storm
同理,“一键停止集群也是相当于执行了:./stop-cluster.sh
在Kafka界面中的SparkStreamingWordCount程序,实际上是经过scala处理后将结果写入本机MySQL数据库:
因此需要新建一个数据库用来存放WordCount结果,并且最好不要用root用户(这里我用的之前新建的名为hive的用户)
mysql -u root -p
create user hive@'localhost' identified by 'hive';
update mysql.user set host = '%' where user = 'hive';
FLUSH PRIVILEGES;
GRANT ALL PRIVILEGES ON *.* TO 'hive'@'%' WITH GRANT OPTION;
mysql -u hive -p # 密码也是hive
create database spark;
use spark;
create table wordcount(word varchar(100),count int);
创建了一个名为“spark”的数据库并在该数据库中建造了一张名为“wordcount”的表
首先在IDEA中启动StreamingKafkaWordCount程序,然后将其中的内容展开复制下来替换掉config
包下的InitConfig.java
中的private static final String wordCountCmd
中的内容:
首先获取到本机java安装路径下的 jps.exe
执行文件的路径:
然后将其中的内容展开复制下来替换掉config
包下的InitConfig.java
中的private static final String jpsCmd
中的内容:
创建主题topictest
和topictest2
/opt/modules/kafka_2.11-2.0.0/bin/kafka-topics.sh --create --zookeeper centos01:2181,centos02:2181,centos03:2181 --replication-factor 2 --partitions 2 --topic topictest
/opt/modules/kafka_2.11-2.0.0/bin/kafka-topics.sh --create --zookeeper centos01:2181,centos02:2181,centos03:2181 --replication-factor 2 --partitions 2 --topic topictest2
通过配置静态变量wordCountCmd
、jpsCmd
并将其getter方法作为Bean进行注入,需要使用时将其自动装配即可:
@Autowired
private InitConfig initConfig;
/* ... */
initConfig.getWordCountCmd()
initConfig.getJpsCmd()
/* ... */
这里不能通过application.yml
配置文件进行注入,因为项目在启动时就需要启动StreamingKafkaWordCount
,而此时还不能通过@Value
注解来获取配置文件中的值,因此只能通过配置类中的静态变量来获取
大部分页面都采用了前后端分离,只有HBase的详情页面没有采用前后端分离,因此除了页面控制器
PageController
采用@Controlle
r注解,其余所有控制器都采用的@RestController
注解且请求URL都以“/api/”开头所有有
@RestController
的类都有一个静态内部类继承了自定义的utils
工具包中的ResultMapToJson
来返回统一格式的json数据作为请求的返回值静态起源的请求都通用的
@GetMapping
,其他请求同意用的@PostMapping
,没有使用@PutMapping
、@DeleteMapping
等(因为前端请求时可以统一使用$.post
解决,就不需要麻烦的使用$.ajax
进行请求还要指定请求类型)
所有方法都加了@GetMapping
注解用来接受页面请求,返回resource
资源文件夹中的templates
文件夹中的html页面
处理/shell
页面发来的请求
具体实现通过自定义的utils
工具包中的ShellUtil
来实现
处理/hdfs
页面发来的请求
实现了一些基本的HDFS操作,根据不同的请求来执行不同的任务
处理/kafka
页面发来的请求
实现了基本的Kafka操作以及调用scala编写的`StreamingKafkaWordCount程序
StreamingKafkaWordCount
程序的启动和停止通过自定义的utils
工具包中的ScalaUtil
来实现(再进一步是通过Runtime.getRuntime().exec()
执行命令来实现的)
清理数据库通过自定义的utils
工具包中的MysqlUtil
来实现
/mapreduce
页面发来的请求执行单词计数utils
工具包中的WordCount
来实现/hbase
页面发来的请求utils
工具包中的HBaseUtil
来实现utils
工具包中的所有的类都添加了@Component
注解注入到spring容器中
作为java连接集群操作Shell脚本的单例类,供ShellUtil
使用
通过com.jcraft.jsch
包实现java连接远程Linux主机并操作shell脚本
私有属性session
、exec
及其getter、setter方法供ShellUtil
创建连接实例
execCommand(String host, String command)
方法用来在host
主机上执行command
命令,执行结果返回一个String类型的List,调用者可将其转为json格式用作请求的返回值ShellConnectionSignal
的session
、exec
的setter、getter方法创建实例后调用该实例的connect()
方法创建连接,执行完毕后调用close()
方法关闭连接MySqlUtil
使用connection
及其getter、setter方法供MysqlUtil
创建连接实例私有final变量mysql
为MySQLConnectionSignal
的实例
其getConnection()
方法通过调用mysql
的setConnection()
方法设置mysql连接对象所需属性后,返回一个mysql
的getConnection()
方法的返回对象,进而 获得一个java.sql.Connection
连接对象去执行操作
MapReduce
实现单词计数,返回String类型的结果,形如[(xxx, 1),(yyy, 2), ... , (String, int)]
getConnection()
获得一个org.apache.hadoop.hbase.client.Connection
对象的实例,然后再进行相应的操作getCount(List<String> list, String s)
,用来判断字符串s
在列表list
中出现的次数,返回值类型为int
抽象类
对com.alibaba.fastjson.JSON
的toJSONString()
方法做了进一步的封装,getResult()
方法返回形如{"msg":"success/error", "detail":"..."}
的统一格式数据,供前端请求时进行响应;后端代码都包含在try语句中,若出现异常,则会将e.toString()
赋值给detail
,前端则会显示出报错而不会500,例如:
通过java程序调用scala程序`StreamingKafkaWordCount的桥梁
内涵两个方法startStreamingKafkaWordCount()
和stopStreamingKafkaWordCount()
分别是启动和关闭`StreamingKafkaWordCount程序
启动是通过执行InitConfig
的wordCountCmd
命令;终止则是先通过InitConfig
的jpsCmd
获取到StreamingKafkaWordCount
的端口然后通过taskkill
命令将其杀死;他们的执行都是通过Runtime.getRuntime().exec()
实现的
/kafka
页面中的【清空】按钮就是调用了stopStreamingKafkaWordCount()
方法先停止StreamingKafkaWordCount
程序,清空mysql数据库后再调用startStreamingKafkaWordCount()
程序启动StreamingKafkaWordCount()
程序
@SpringBootApplication
注解标志着这个类是程序的启动类System.setProperty("HADOOP_USER_NAME", "hadoop");
指明了该程序对Hadoop集群的一切操作的权限都是hadoop
用户而非root
Runtime.getRuntime().exec(initConfig.getWordCountCmd());
表示程序在启动之初就会执行StreamingKafkaWordCount
程序StreamingKafkaWordCount
是由scala编写的一个类ScalaUtil
调用执行原文链接:https://blog.csdn.net/qq_43613793/article/details/117303208
作者:我是一个射手
链接:http://www.javaheidong.com/blog/article/207371/4840e963eab1a8313aa8/
来源:java黑洞网
任何形式的转载都请注明出处,如有侵权 一经发现 必将追究其法律责任
昵称:
评论内容:(最多支持255个字符)
---无人问津也好,技不如人也罢,你都要试着安静下来,去做自己该做的事,而不是让内心的烦躁、焦虑,坏掉你本来就不多的热情和定力
Copyright © 2018-2021 java黑洞网 All Rights Reserved 版权所有,并保留所有权利。京ICP备18063182号-2
投诉与举报,广告合作请联系vgs_info@163.com或QQ3083709327
免责声明:网站文章均由用户上传,仅供读者学习交流使用,禁止用做商业用途。若文章涉及色情,反动,侵权等违法信息,请向我们举报,一经核实我们会立即删除!