Centos7 安装Flink1.16

2023-11-06  本文已影响0人  Yobhel

1 集群角色

image.png

2 Flink集群搭建

2.1 集群启动

0)集群规划

节点服务器 hadoop101 hadoop102 hadoop103
角色 JobManager
TaskManager
TaskManager TaskManager

具体安装部署步骤如下:
1)下载并解压安装包

(1)下载安装包flink-1.16.1-bin-scala_2.12.tgz,将该jar包上传到hadoop101节点服务器的/opt/software路径上。

(2)在/opt/software路径上解压flink-1.16.1-bin-scala_2.12.tgz到/opt/module路径上。

[yobhel@hadoop101 software]$ tar -zxvf flink-1.16.1-bin-scala_2.12.tgz -C /opt/module/

2)修改集群配置

(1)进入conf路径,修改flink-conf.yaml文件,指定hadoop101节点服务器为JobManager

[yobhel@hadoop101 conf]$ vim flink-conf.yaml

修改如下内容:

# JobManager节点地址.
jobmanager.rpc.address: hadoop101
jobmanager.bind-host: hadoop101
rest.address: hadoop101
rest.bind-address: hadoop101
# TaskManager节点地址.需要配置为当前机器名
taskmanager.bind-host: hadoop101
taskmanager.host: hadoop101

之后分发flink到hadoop102和hadoop103机器,并修改以下参数为当前主机名,例如以修改hadoop102机器的配置为例:

taskmanager.bind-host: hadoop102
taskmanager.host: hadoop103

(2)在需要执行群起命令的机器,修改workers文件

[yobhel@hadoop101 conf]$ vim workers

修改如下内容:

hadoop101
hadoop102
hadoop103

(3)在需要执行群起命令的机器,修改masters文件

[yobhel@hadoop101 conf]$ vim masters

修改如下内容:

hadoop101:8081

(4)另外,在flink-conf.yaml文件中还可以对集群中的JobManager和TaskManager组件进行优化配置,主要配置项如下:

关于Slot和并行度的概念,我们会在下一章做详细讲解。

3)启动集群

(1)在hadoop101节点服务器上执行start-cluster.sh启动Flink集群:

[yobhel@hadoop101 flink-1.16.1]$ bin/start-cluster.sh

(2)查看进程情况:

[yobhel@hadoop101 flink-1.16.1]$ jpsall 
=============== hadoop101 ===============
4453 StandaloneSessionClusterEntrypoint
4458 TaskManagerRunner
4533 Jps
=============== hadoop102 ===============
2872 TaskManagerRunner
2941 Jps
=============== hadoop103 ===============
2948 Jps
2876 TaskManagerRunner

4)访问Web UI

启动成功后,同样可以访问http://hadoop101:8081对flink集群和任务进行监控管理。

image.png

2.2 命令行向集群提交作业

除了通过WEB UI界面提交任务之外,也可以直接通过命令行来提交任务。这里为方便起见,我们可以先把jar包直接上传到目录flink-1.16.1下

(1)首先需要启动集群。

[yobhel@hadoop101 flink-1.16.1]$ bin/start-cluster.sh

(2)在hadoop101中执行以下命令启动netcat。

[yobhel@hadoop101 flink-1.16.1]$ nc -lk 7777

(3)将flink程序运行jar包上传到/opt/module/flink-1.16.1路径。

(4)进入到flink的安装路径下,在命令行使用flink run命令提交作业。

[yobhel@hadoop101 flink-1.16.1]$ bin/flink run -m hadoop101:8081 -c com.yobhel.wc.SocketStreamWordCount ./FlinkTutorial-1.0-SNAPSHOT.jar

这里的参数 -m指定了提交到的JobManager,-c指定了入口类。

(5)在浏览器中打开Web UI,http://hadoop101:8081查看应用执行情况

用netcat输入数据,可以在TaskManager的标准输出(Stdout)看到对应的统计结果


image.png

(6)在/opt/module/flink-1.16.1/log路径中,可以查看TaskManager节点。

[yobhel@hadoop101 log]$ cat flink-yobhel-standalonesession-0-hadoop101.out

(hello,1)
(hello,2)
(flink,1)
(hello,3)
(scala,1)

3 部署模式

在一些应用场景中,对于集群资源分配和占用的方式,可能会有特定的需求。Flink为各种场景提供了不同的部署模式,主要有以下三种:会话模式(Session Mode)、单作业模式(Per-Job Mode)、应用模式(Application Mode)。
它们的区别主要在于:集群的生命周期以及资源的分配方式;以及应用的main方法到底在哪里执行——客户端(Client)还是JobManager。

3.1 会话模式(Session Mode)

image.png

3.2 单作业模式(Per-Job Mode)

image.png

3.3 应用模式(Application Mode)

image.png

这里我们所讲到的部署模式,相对是比较抽象的概念。实际应用时,一般需要和资源管理平台结合起来,选择特定的模式来分配资源、部署应用。接下来,我们就针对不同的资源提供者的场景,具体介绍Flink的部署方式。

4 Standalone运行模式(了解)

独立模式是独立运行的,不依赖任何外部的资源管理平台;当然独立也是有代价的:如果资源不足,或者出现故障,没有自动扩展或重分配资源的保证,必须手动处理。所以独立模式一般只用在开发测试或作业非常少的场景下。

4.1 会话模式部署

我们在第2节用的就是Standalone集群的会话模式部署。
提前启动集群,并通过Web页面客户端提交任务(可以多个任务,但是集群资源固定)。


image.png

4.2 单作业模式部署

Flink的Standalone集群并不支持单作业模式部署。因为单作业模式需要借助一些资源管理平台。

4.3 应用模式部署

应用模式下不会提前创建集群,所以不能调用start-cluster.sh脚本。我们可以使用同样在bin目录下的standalone-job.sh来创建一个JobManager。


image.png

具体步骤如下:
(0)环境准备。在hadoop101中执行以下命令启动netcat。

[yobhel@hadoop101 flink-1.16.1]$ nc -lk 7777

(1)进入到Flink的安装路径下,将应用程序的jar包放到lib/目录下。

[yobhel@hadoop101 flink-1.16.1]$ mv FlinkTutorial-1.0-SNAPSHOT.jar lib/

(2)执行以下命令,启动JobManager。

[yobhel@hadoop101 flink-1.16.1]$ bin/standalone-job.sh start --job-classname com.yobhel.wc.SocketStreamWordCount

这里我们直接指定作业入口类,脚本会到lib目录扫描所有的jar包。
(3)同样是使用bin目录下的脚本,启动TaskManager。

[yobhel@hadoop101 flink-1.16.1]$ bin/taskmanager.sh start

(4)在hadoop101上模拟发送单词数据。

[yobhel@hadoop101 ~]$ nc -lk 7777
hello

(5)在hadoop101:8081地址中观察输出数据


image.png

(6)如果希望停掉集群,同样可以使用脚本,命令如下。

[yobhel@hadoop101 flink-1.16.1]$ bin/taskmanager.sh stop
[yobhel@hadoop101 flink-1.16.1]$ bin/standalone-job.sh stop

5 YARN运行模式(重点)

YARN上部署的过程是:客户端把Flink应用提交给Yarn的ResourceManager,Yarn的ResourceManager会向Yarn的NodeManager申请容器。在这些容器上,Flink会部署JobManager和TaskManager的实例,从而启动集群。Flink会根据运行在JobManger上的作业所需要的Slot数量动态分配TaskManager资源。
5.1 相关准备和配置
在将Flink任务部署至YARN集群之前,需要确认集群是否安装有Hadoop,保证Hadoop版本至少在2.2以上,并且集群中安装有HDFS服务。
具体配置步骤如下:
(1)配置环境变量,增加环境变量配置如下:

$ sudo vim /etc/profile.d/my_env.sh

HADOOP_HOME=/opt/module/hadoop-3.1.3
export PATH=$PATH:$HADOOP_HOME/bin:$HADOOP_HOME/sbin
export HADOOP_CONF_DIR=${HADOOP_HOME}/etc/hadoop
export HADOOP_CLASSPATH=`hadoop classpath`

(2)启动Hadoop集群,包括HDFS和YARN。

[yobhel@hadoop101 hadoop-3.1.3]$ start-dfs.sh
[yobhel@hadoop102 hadoop-3.1.3]$ start-yarn.sh

(3)在hadoop101中执行以下命令启动netcat。

[yobhel@hadoop101 flink-1.16.1]$ nc -lk 7777

5.2 会话模式部署

YARN的会话模式与独立集群略有不同,需要首先申请一个YARN会话(YARN Session)来启动Flink集群。具体步骤如下:
1)启动集群
(1)启动Hadoop集群(HDFS、YARN)。
(2)执行脚本命令向YARN集群申请资源,开启一个YARN会话,启动Flink集群。
[yobhel@hadoop101 flink-1.16.1]$ bin/yarn-session.sh -nm test
可用参数解读:

2022-11-17 15:20:52,711 INFO  org.apache.flink.yarn.YarnClusterDescriptor                  [] - Found Web Interface hadoop103:40825 of application 'application_1668668287070_0005'.
JobManager Web Interface: http://hadoop103:40825

2)提交作业
(1)通过Web UI提交作业
这种方式比较简单,与上文所述Standalone部署模式基本相同。


image.png

(2)通过命令行提交作业
① 将FlinkTutorial-1.0-SNAPSHOT.jar任务上传至集群。
② 执行以下命令将该任务提交到已经开启的Yarn-Session中运行。

[yobhel@hadoop101 flink-1.16.1]$ bin/flink run
-c com.yobhel.wc.SocketStreamWordCount FlinkTutorial-1.0-SNAPSHOT.jar

客户端可以自行确定JobManager的地址,也可以通过-m或者-jobmanager参数指定JobManager的地址,JobManager的地址在YARN Session的启动页面中可以找到。
③ 任务提交成功后,可在YARN的Web UI界面查看运行情况。hadoop102:8088。


image.png

从上图中可以看到我们创建的Yarn-Session实际上是一个Yarn的Application,并且有唯一的Application ID。
④也可以通过Flink的Web UI页面查看提交任务的运行情况,如下图所示。


image.png

5.3 单作业模式部署

在YARN环境中,由于有了外部平台做资源调度,所以我们也可以直接向YARN提交一个单独的作业,从而启动一个Flink集群。
(1)执行命令提交作业。

[yobhel@hadoop101 flink-1.16.1]$ bin/flink run -d -t yarn-per-job -c com.yobhel.wc.SocketStreamWordCount FlinkTutorial-1.0-SNAPSHOT.jar

注意:如果启动过程中报如下异常。

Exception in thread “Thread-5” java.lang.IllegalStateException: Trying to access closed classloader. Please check if you store classloaders directly or indirectly in static fields. If the stacktrace suggests that the leak occurs in a third party library and cannot be fixed immediately, you can disable this check with the configuration ‘classloader.check-leaked-classloader’.
at org.apache.flink.runtime.execution.librarycache.FlinkUserCodeClassLoaders

解决办法:在flink的/opt/module/flink-1.16.1/conf/flink-conf.yaml配置文件中设置

[yobhel@hadoop101 conf]$ vim flink-conf.yaml

classloader.check-leaked-classloader: false

(2)在YARN的ResourceManager界面查看执行情况。


image.png

点击可以打开Flink Web UI页面进行监控,如下图所示:


image.png

(3)可以使用命令行查看或取消作业,命令如下。

[yobhel@hadoop101 flink-1.16.1]$ bin/flink list -t yarn-per-job -Dyarn.application.id=application_XXXX_YY

[yobhel@hadoop101 flink-1.16.1]$ bin/flink cancel -t yarn-per-job -Dyarn.application.id=application_XXXX_YY <jobId>

这里的application_XXXX_YY是当前应用的ID,<jobId>是作业的ID。注意如果取消作业,整个Flink集群也会停掉。

5.4 应用模式部署

应用模式同样非常简单,与单作业模式类似,直接执行flink run-application命令即可。
(1)执行命令提交作业。

[yobhel@hadoop101 flink-1.16.1]$ bin/flink run-application -t yarn-application -c com.yobhel.wc.SocketStreamWordCount FlinkTutorial-1.0-SNAPSHOT.jar 

(2)在命令行中查看或取消作业。

[yobhel@hadoop101 flink-1.16.1]$ bin/flink list -t yarn-application -Dyarn.application.id=application_XXXX_YY

[yobhel@hadoop101 flink-1.16.1]$ bin/flink cancel -t yarn-application -Dyarn.application.id=application_XXXX_YY <jobId>

(3)也可以通过yarn.provided.lib.dirs配置选项指定位置,将jar上传到远程。

[yobhel@hadoop101 flink-1.16.1]$ bin/flink run-application -t yarn-application  -Dyarn.provided.lib.dirs="hdfs://myhdfs/my-remote-flink-dist-dir"   hdfs://myhdfs/jars/my-application.jar

这种方式下jar可以预先上传到HDFS,而不需要单独发送到集群,这就使得作业提交更加轻量了。

6 历史服务器

运行 Flinkjob 的集群一旦停止,只能去yarn 或本地磁盘上查看日志,不再可以查看作业挂掉之前的运行的 Web UI,很难清楚知道作业在挂的那一刻到底发生了什么。如果我们还没有 Metrics 监控的话,那么完全就只能通过日志去分析和定位问题了,所以如果能还原之前的 Web UI,我们可以通过 UI 发现和定位一些问题。

Flink提供了历史服务器,用来在相应的 Flink 集群关闭后查询已完成作业的统计信息。我们都知道只有当作业处于运行中的状态,才能够查看到相关的WebUI统计信息。通过 History Server 我们才能查询这些已完成作业的统计信息,无论是正常退出还是异常退出。

此外,它对外提供了 REST API,它接受 HTTP 请求并使用 JSON 数据进行响应。Flink 任务停止后,JobManager 会将已经完成任务的统计信息进行存档,History Server 进程则在任务停止后可以对任务统计信息进行查询。比如:最后一次的 Checkpoint、任务运行时的相关配置。

1)创建存储目录

hadoop fs -mkdir -p /logs/flink-job

2)在 flink-config.yaml中添加如下配置

jobmanager.archive.fs.dir: hdfs://hadoop101:8020/logs/flink-job
historyserver.web.address: hadoop101
historyserver.web.port: 8082
historyserver.archive.fs.dir: hdfs://hadoop101:8020/logs/flink-job
historyserver.archive.fs.refresh-interval: 5000

3)启动历史服务器

bin/historyserver.sh start

4)停止历史服务器

bin/historyserver.sh  stop

5)在浏览器地址栏输入:<u>http://hadoop101:8082</u>查看已经停止的job的统计信息

上一篇下一篇

猜你喜欢

热点阅读