Apache Flink-Flink 애플리케이션 생성

이 장에서는 Flink 애플리케이션을 만드는 방법을 배웁니다.

Eclipse IDE를 열고 새 프로젝트를 클릭하고 Java 프로젝트를 선택하십시오.

프로젝트 이름을 지정하고 마침을 클릭합니다.

이제 다음 스크린 샷과 같이 마침을 클릭합니다.

이제 마우스 오른쪽 버튼으로 src New >> Class로 이동합니다.

수업 이름을 입력하고 마침을 클릭합니다.

편집기에서 아래 코드를 복사하여 붙여 넣으십시오.

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));
            }
         }
      }
   }
}

이 프로젝트에 Flink 라이브러리를 추가해야하므로 편집기에서 많은 오류가 발생합니다.

프로젝트 >> 빌드 경로 >> 빌드 경로 구성을 마우스 오른쪽 버튼으로 클릭하십시오.

라이브러리 탭을 선택하고 외부 JAR 추가를 클릭하십시오.

Flink의 lib 디렉토리로 이동하여 4 개의 라이브러리를 모두 선택한 다음 확인을 클릭합니다.

주문 및 내보내기 탭으로 이동하여 모든 라이브러리를 선택하고 확인을 클릭합니다.

오류가 더 이상 존재하지 않음을 알 수 있습니다.

이제이 응용 프로그램을 내보내겠습니다. 프로젝트를 마우스 오른쪽 버튼으로 클릭하고 내보내기를 클릭합니다.

JAR 파일을 선택하고 다음을 클릭하십시오.

대상 경로를 지정하고 다음을 클릭하십시오.

다음을 클릭>

찾아보기를 클릭하고 기본 클래스 (WordCount)를 선택한 후 완료를 클릭하십시오.

Note − 경고가 표시되면 확인을 클릭합니다.

아래 명령을 실행하십시오. 방금 만든 Flink 응용 프로그램을 추가로 실행합니다.

./bin/flink run /home/ubuntu/wordcount.jar --input README.txt --output /home/ubuntu/output