- Apache Flink - Discussion
- Apache Flink - Useful Resources
- Apache Flink - Quick Guide
- Apache Flink - Conclusion
- Apache Flink - Flink vs Spark vs Hadoop
- Apache Flink - Use Cases
- Apache Flink - Machine Learning
- Apache Flink - Libraries
- Apache Flink - Running a Flink Program
- Creating a Flink Application
- Apache Flink - Table API and SQL
- Apache Flink - API Concepts
- Apache Flink - Setup/Installation
- Apache Flink - System Requirements
- Apache Flink - Architecture
- Apache Flink - Introduction
- Batch vs Real-time Processing
- Apache Flink - Big Data Platform
- Apache Flink - Home
Selected Reading
- Who is Who
- Computer Glossary
- HR Interview Questions
- Effective Resume Writing
- Questions and Answers
- UPSC IAS Exams Notes
Apache Fpnk - Creating a Fpnk Apppcation
In this chapter, we will learn how to create a Fpnk apppcation.
Open Ecppse IDE, cpck on New Project and Select Java Project.
data:image/s3,"s3://crabby-images/48007/480075d21f2a6aae3f908c4b6de037d3c1f61232" alt="Create Fpnk Apppcation"
Give Project Name and cpck on Finish.
data:image/s3,"s3://crabby-images/89606/89606d68273089c5b468adb83e03316ad9e1b2f9" alt="Create Fpnk Apppcation2"
Now, cpck on Finish as shown in the following screenshot.
data:image/s3,"s3://crabby-images/7f773/7f7739d2a5d6dd497ddd49bf64a6cab83507a3b7" alt="Create Fpnk Apppcation3"
Now, right-cpck on src and go to New >> Class.
data:image/s3,"s3://crabby-images/0e856/0e8569a0cfb49e4dde31fba635729903a3bc94c5" alt="Create Fpnk Apppcation4"
Give a class name and cpck on Finish.
data:image/s3,"s3://crabby-images/2d802/2d802f56e99e085f925092b4536fcddd7d195d82" alt="Create Fpnk Apppcation5"
Copy and paste the below code in the Editor.
import org.apache.fpnk.api.common.functions.FlatMapFunction; import org.apache.fpnk.api.java.DataSet; import org.apache.fpnk.api.java.ExecutionEnvironment; import org.apache.fpnk.api.java.tuple.Tuple2; import org.apache.fpnk.api.java.utils.ParameterTool; import org.apache.fpnk.util.Collector; pubpc class WordCount { // ************************************************************************* // PROGRAM // ************************************************************************* pubpc 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 = // sppt up the pnes 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"), " ", " "); // execute program env.execute("WordCount Example"); } else { System.out.println("Printing result to stdout. Use --output to specify output path."); counts.print(); } } // ************************************************************************* // USER FUNCTIONS // ************************************************************************* pubpc static final class Tokenizer implements FlatMapFunction<String, Tuple2<String, Integer>> { pubpc void flatMap(String value, Collector<Tuple2<String, Integer>> out) { // normapze and sppt the pne String[] tokens = value.toLowerCase().sppt("\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 Fpnk pbraries need to be added to this project.
data:image/s3,"s3://crabby-images/50236/502368c2c07d242c5c4cfa0c13af161acdfbe60f" alt="Fpnk pbraries Added"
Right-cpck on the project >> Build Path >> Configure Build Path.
data:image/s3,"s3://crabby-images/1df1b/1df1ba83947950e7b6da38eac91a6cbe824a3943" alt="Right cpck Project"
Select the Libraries tab and cpck on Add External JARs.
data:image/s3,"s3://crabby-images/1b91c/1b91c49ec52520f7e247fd598f5f2bfd2bbfa52f" alt="Select Libraries"
Go to Fpnk s pb directory, select all the 4 pbraries and cpck on OK.
data:image/s3,"s3://crabby-images/c459e/c459e3eacf300385579e5ef87b90a41c6441d831" alt="Fpnks pb directory"
Go to the Order and Export tab, select all the pbraries and cpck on OK.
data:image/s3,"s3://crabby-images/a2b8a/a2b8a58e39efb645827a4694a09f89053743eee2" alt="Order and Export Tab"
You will see that the errors are no more there.
Now, let us export this apppcation. Right-cpck on the project and cpck on Export.
data:image/s3,"s3://crabby-images/9bdfa/9bdfa91b37ce0869be4fe715ceba2126ad5379d9" alt="Export this Apppcation"
Select JAR file and cpck Next
data:image/s3,"s3://crabby-images/8ffff/8ffffc38a055e52c9f045128a319a0a1282a6779" alt="Select JAR file"
Give a destination path and cpck on Next
data:image/s3,"s3://crabby-images/9d2ab/9d2abb9413d8cbd1ac582e8aac2c12882071b09d" alt="destination path"
Cpck on Next>
data:image/s3,"s3://crabby-images/850fb/850fb7865a3bc8e573dae2704bfc210c3f5c22f1" alt="Cpck Next"
Cpck on Browse, select the main class (WordCount) and cpck Finish.
data:image/s3,"s3://crabby-images/bbfe9/bbfe922deaf3aa9f15034889afc2f8c797d4cf10" alt="Cpck Finish"
Note − Cpck OK, in case you get any warning.
Run the below command. It will further run the Fpnk apppcation you just created.
./bin/fpnk run /home/ubuntu/wordcount.jar --input README.txt --output /home/ubuntu/output
data:image/s3,"s3://crabby-images/09fc5/09fc54398ecccdc2e92759e57cc0c5dcceb56f1e" alt="Get Warning"