Flink高手之路1一Flink的简介


一、Flink简介

1. Fink的引入

大数据的计算引擎,发展过程有四个阶段

  • 第一代:Hadoop的MapReduce,批处理,中间结果放在HDFS上也就是硬盘上,速度很慢,效率很低
  • 第二代:支持DAG(有向无环图),Tez和Oozie,批处理
  • 第三代:内存计算,Spark,支持批处理和流(实时)处理,比MR快100倍以上
  • 第四代:Flink,真正的流批一体,比Spark更快

2.Flink简介

Apache Flink是由Apache软件基金会开发的开源流处理框架,其核心是用Java和Scala编写的分布式流数据流引擎。Flink以数据并行和流水线方式执行任意流数据程序,Flink的流水线运行时系统可以执行批处理和流处理程序。此外,Flink的运行时本身也支持迭代算法的执行。

Flink的官网:https://flink.apache.org/

image-20230224202456682

基于数据流的状态计算

image-20230224202526181

3.支持的编程语言

Flink对java、scala、python都提供支持,但是Flink使用java开发,最适合java,课程以java语言为例。

4.Flink的特性

image-20230224203453948

Flink是一个计算框架和分布式的计算处理引擎,基于对流(实时、无界)和批(离散、有界)数据进行有状态的计算,它可以通过集群以内存进行任意规模的数据计算。

  • 高吞吐、低延迟、高性能
  • 支持带有事件的窗口(window)操作
  • 支持有状态的计算
  • 内存计算
  • 迭代计算

5.Flink四大基石

  • 校验点Checkpoint
  • 状态State
  • Time时间
  • 窗口Window

6.批处理和流处理

  • 批处理:有界、持久、大量,处理引擎:MR、SparkSQL、Flink DataSet现在合并为DataStream
  • 流处理:无界、实时、持续,处理引擎:Spark Streaming,Flink DataSteam

二、Flink的架构

1.Flink的角色

  • JobManager

    也叫做Master,用于协调分布式执行、调度任务(task)、协调校验点、协调失败时的恢复,可以配置为高可用(HA),当配置高可用时,只有一台是active,其他的为standby

  • TaskManager

    也叫做worker,用于执行计算任务,进行数据缓存和交换,至少得有一个worker

2.编程模型

image-20230224203219708

  • ProcessFunction

    image-20230224203647296

  • DataStream API

    image-20230224203725088

  • SQL & Table API

    image-20230224203813509

参考文章:

Flink-百度百科

Flink官网

猜你喜欢

转载自blog.csdn.net/W_chuanqi/article/details/129211351