当前位置:   article > 正文

flink开发案例_简单三步实现 Flink 环境搭建,618 再也不愁了!

完成flink入门例子的环境搭建编码及测试

70bc1817175401a884cde763faed331e.png
作者简介:王知无,资深大数据工程师。本文选自:拉勾教育专栏《42讲轻松通关 Flink》

本课时我们主要介绍 Flink 的入门程序以及 SQL 形式的实现。

上一课时已经讲解了 Flink 的常用应用场景和架构模型设计,这一课时我们将会从一个最简单的 WordCount 案例作为切入点,并且同时使用 SQL 方式进行实现,为后面的实战课程打好基础。

本文选自:拉勾教育专栏《42讲轻松通关 Flink》

Flink 开发环境

通常来讲,任何一门大数据框架在实际生产环境中都是以集群的形式运行,而我们调试代码大多数会在本地搭建一个模板工程,Flink 也不例外。

Flink 一个以 Java 及 Scala 作为开发语言的开源大数据项目,通常我们推荐使用 Java 来作为开发语言,Maven 作为编译和包管理工具进行项目构建和编译。对于大多数开发者而言,JDK、Maven 和 Git 这三个开发工具是必不可少的。

关于 JDK、Maven 和 Git 的安装建议如下表所示:

工具

版本建议

备注

JDK

1.8 或以上

Maven

建议 Maven 3.2.5

官网:https://maven.apache.org/download.cgi

Git

无特殊要求

建议跟随官网最新版本

Git 官网:https://git-scm.com/downloads

Flink 仓库: https://github.com/apache/flink

系统

推荐使用 Linux 系统

工程创建

一般来说,我们在通过 IDE 创建工程,可以自己新建工程,添加 Maven 依赖,或者直接用 mvn 命令创建应用:

  1. mvn archetype:generate
  2. -DarchetypeGroupId=org.apache.flink
  3. -DarchetypeArtifactId=flink-quickstart-java
  4. -DarchetypeVersion=1.10.0

通过指定 Maven 工程的三要素,即 GroupId、ArtifactId、Version 来创建一个新的工程。同时 Flink 给我提供了更为方便的创建 Flink 工程的方法:

curl https://flink.apache.org/q/quickstart.sh | bash -s 1.10.0

我们在终端直接执行该命令:

7e844dd50cb0bdf7abe9c6b3b8a5bf5a.png

bb8b04f0a4b00cd231287692e0b03e94.png

直接出现 Build Success 信息,我们可以在本地目录看到一个已经生成好的名为 quickstart 的工程。

这里需要的主要的是,自动生成的项目 pom.xml 文件中对于 Flink 的依赖注释掉 scope:

  1. <dependency>
  2. <groupId>org.apache.flink</groupId>
  3. <artifactId>flink-java</artifactId>
  4. <version>${flink.version}</version>
  5. <!--<scope>provided</scope>-->
  6. </dependency>
  7. <dependency>
  8. <groupId>org.apache.flink</groupId>
  9. <artifactId>flink-streaming-java_${scala.binary.version}</artifactId>
  10. <version>${flink.version}</version>
  11. <!--<scope>provided</scope>-->
  12. </dependency>

本文选自:拉勾教育专栏《42讲轻松通关 Flink》

DataSet WordCount

WordCount 程序是大数据处理框架的入门程序,俗称“单词计数”。用来统计一段文字每个单词的出现次数,该程序主要分为两个部分:一部分是将文字拆分成单词;另一部分是单词进行分组计数并打印输出结果。

整体代码实现如下:

  1. public static void main(String[] args) throws Exception {
  2. // 创建Flink运行的上下文环境
  3. final ExecutionEnvironment env = ExecutionEnvironment.getExecutionEnvironment();
  4. // 创建DataSet,这里我们的输入是一行一行的文本
  5. DataSet<String> text = env.fromElements(
  6. "Flink Spark Storm",
  7. "Flink Flink Flink",
  8. "Spark Spark Spark",
  9. "Storm Storm Storm"
  10. );
  11. // 通过Flink内置的转换函数进行计算
  12. DataSet<Tuple2<String, Integer>> counts =
  13. text.flatMap(new LineSplitter())
  14. .groupBy(0)
  15. .sum(1);
  16. //结果打印
  17. counts.printToErr();
  18. }
  19. public static final class LineSplitter implements FlatMapFunction<String, Tuple2<String, Integer>> {
  20. @Override
  21. public void flatMap(String value, Collector<Tuple2<String, Integer>> out) {
  22. // 将文本分割
  23. String[] tokens = value.toLowerCase().split("W+");
  24. for (String token : tokens) {
  25. if (token.length() > 0) {
  26. out.collect(new Tuple2<String, Integer>(token, 1));
  27. }
  28. }
  29. }

实现的整个过程中分为以下几个步骤。

首先,我们需要创建 Flink 的上下文运行环境:

ExecutionEnvironment env = ExecutionEnvironment.getExecutionEnvironment();

然后,使用 fromElements 函数创建一个 DataSet 对象,该对象中包含了我们的输入,使用 FlatMap、GroupBy、SUM 函数进行转换。

最后,直接在控制台打印输出。

总结

本课时介绍了 Flink 的工程创建。第一次体验了 Flink SQL 的强大之处,让你有一个直观的认识,为后续内容打好基础。

以上就是本课时的内容。在下一课时中,我将介绍“Flink 的编程模型与其他框架比较”,下一课时见。

本文选自:拉勾教育专栏《42讲轻松通关 Flink》

版权声明:本文版权归属拉勾教育及该专栏作者,任何媒体、网站或个人未经本网协议授权不得转载、链接、转贴或以其他方式复制发布/发表,违者必究。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小丑西瓜9/article/detail/598066
推荐阅读
相关标签
  

闽ICP备14008679号