data:image/s3,"s3://crabby-images/f1cee/f1ceee2a6208eb16d57601a6b8b8a539a74b1b1b" alt="Apache Flink 教程"
- Apache Flink 教程
- Apache Flink - 主页
- Apache Flink - 大数据平台
- 批处理与实时处理
- Apache Flink - 简介
- Apache Flink - 架构
- Apache Flink - 系统要求
- Apache Flink - 设置/安装
- Apache Flink - API 概念
- Apache Flink - 表 API 和 SQL
- 创建 Flink 应用程序
- Apache Flink - 运行 Flink 程序
- Apache Flink - 库
- Apache Flink - 机器学习
- Apache Flink - 用例
- Apache Flink - Flink、Spark、Hadoop
- Apache Flink - 结论
- Apache Flink 资源
- Apache Flink - 快速指南
- Apache Flink - 有用的资源
- Apache Flink - 讨论
Apache Flink - Creating a Flink Application
In this chapter, we will learn how to create a Flink application.
Open Eclipse IDE, click on New Project and Select Java Project.
data:image/s3,"s3://crabby-images/a5160/a5160dae0dce39587002dbc332c55da758120264" alt="Create Flink Application"
Give Project Name and click on Finish.
data:image/s3,"s3://crabby-images/25767/2576778baa206d7ba01b0f7dd2690bee44e75c5d" alt="Create Flink Application2"
Now, click on Finish as shown in the following screenshot.
data:image/s3,"s3://crabby-images/4aedf/4aedf9bf1932175389c53242c2aa575b1719fbed" alt="Create Flink Application3"
Now, right-click on src and go to New >> Class.
data:image/s3,"s3://crabby-images/85b6c/85b6cdd4e680ba2ae34bacd37c6fcdead456a41e" alt="Create Flink Application4"
Give a class name and click on Finish.
data:image/s3,"s3://crabby-images/99052/99052d33ba67a310c4bc4b53994fe7f35721efad" alt="Create Flink Application5"
Copy and paste the below code in the Editor.
import org.apache.flink.api.common.functions.FlatMapFunction; import org.apache.flink.api.java.DataSet; import org.apache.flink.api.java.ExecutionEnvironment; import org.apache.flink.api.java.tuple.Tuple2; import org.apache.flink.api.java.utils.ParameterTool; import org.apache.flink.util.Collector; public class WordCount { // ************************************************************************* // PROGRAM // ************************************************************************* public static void main(String[] args) throws Exception { final ParameterTool params = ParameterTool.fromArgs(args); // set up the execution environment final ExecutionEnvironment env = ExecutionEnvironment.getExecutionEnvironment(); // make parameters available in the web interface env.getConfig().setGlobalJobParameters(params); // get input data DataSet<String> text = env.readTextFile(params.get("input")); DataSet<Tuple2<String, Integer>> counts = // split up the lines in pairs (2-tuples) containing: (word,1) text.flatMap(new Tokenizer()) // group by the tuple field "0" and sum up tuple field "1" .groupBy(0) .sum(1); // emit result if (params.has("output")) { counts.writeAsCsv(params.get("output"), "\n", " "); // execute program env.execute("WordCount Example"); } else { System.out.println("Printing result to stdout. Use --output to specify output path."); counts.print(); } } // ************************************************************************* // USER FUNCTIONS // ************************************************************************* public static final class Tokenizer implements FlatMapFunction<String, Tuple2<String, Integer>> { public void flatMap(String value, Collector<Tuple2<String, Integer>> out) { // normalize and split the line String[] tokens = value.toLowerCase().split("\\W+"); // emit the pairs for (String token : tokens) { if (token.length() > 0) { out.collect(new Tuple2<>(token, 1)); } } } } }
You will get many errors in the editor, because Flink libraries need to be added to this project.
data:image/s3,"s3://crabby-images/42261/422612bc7b9fe10c4ec67294f1cb3fd92b1ce723" alt="Flink libraries Added"
Right-click on the project >> Build Path >> Configure Build Path.
data:image/s3,"s3://crabby-images/336da/336da53fe64ee1b5a2512ae2c99284fdff037856" alt="Right click Project"
Select the Libraries tab and click on Add External JARs.
data:image/s3,"s3://crabby-images/51742/517429483ab53a1e4fec5f5c7b2d288082f5a4ce" alt="Select Libraries"
Go to Flink's lib directory, select all the 4 libraries and click on OK.
data:image/s3,"s3://crabby-images/b9a7d/b9a7dfb4a2fbf1f719e2bf56ad9f7d0404dc5591" alt="Flinks lib directory"
Go to the Order and Export tab, select all the libraries and click on OK.
data:image/s3,"s3://crabby-images/ef781/ef781fb6586d933615bea52216813569f9c54e64" alt="Order and Export Tab"
You will see that the errors are no more there.
Now, let us export this application. Right-click on the project and click on Export.
data:image/s3,"s3://crabby-images/ad111/ad111708ce298fc8d643411dc0ff5658b611f72b" alt="Export this Application"
Select JAR file and click Next
data:image/s3,"s3://crabby-images/b60f4/b60f46a1d09485a468dd8f8100289c34142fb13c" alt="Select JAR file"
Give a destination path and click on Next
data:image/s3,"s3://crabby-images/7cdb8/7cdb86608d0caf1982f88be86517af37d9dcda02" alt="destination path"
Click on Next>
data:image/s3,"s3://crabby-images/83870/8387032d047e2db2af1b30d7bfd1ab107a8c757d" alt="Click Next"
Click on Browse, select the main class (WordCount) and click Finish.
data:image/s3,"s3://crabby-images/3dc11/3dc1163a6e0a32b1c8159a18b0fd03b1f5639a7b" alt="Click Finish"
Note − Click OK, in case you get any warning.
Run the below command. It will further run the Flink application you just created.
./bin/flink run /home/ubuntu/wordcount.jar --input README.txt --output /home/ubuntu/output
data:image/s3,"s3://crabby-images/b7321/b7321587feb888a5952f89d6601acfe0ccf77f16" alt="Get Warning"