ApacheFlink-ライブラリ

この章では、ApacheFlinkのさまざまなライブラリについて学習します。

複合イベント処理(CEP)

FlinkCEPはApacheFlinkのAPIであり、継続的なストリーミングデータのイベントパターンを分析します。これらのイベントはほぼリアルタイムであり、スループットが高く、待ち時間が短くなっています。このAPIは主に、リアルタイムで処理が非常に複雑なセンサーデータで使用されます。

CEPは入力ストリームのパターンを分析し、すぐに結果を出します。イベントパターンが複雑な場合に、リアルタイムの通知とアラートを提供する機能があります。FlinkCEPは、さまざまな種類の入力ソースに接続して、それらのパターンを分析できます。

これは、CEPを使用したサンプルアーキテクチャがどのように見えるかです。

センサーデータはさまざまなソースから受信され、Kafkaは分散メッセージングフレームワークとして機能し、ストリームをApache Flinkに分散し、FlinkCEPは複雑なイベントパターンを分析します。

PatternAPIを使用して複雑なイベント処理用のプログラムをApacheFlinkで作成できます。これにより、連続ストリームデータから検出するイベントパターンを決定できます。以下は、最も一般的に使用されるCEPパターンの一部です-

ベギン

開始状態を定義するために使用されます。次のプログラムは、Flinkプログラムでどのように定義されているかを示しています。

Pattern<Event, ?> next = start.next("next");

どこ

これは、現在の状態でのフィルター条件を定義するために使用されます。

patternState.where(new FilterFunction <Event>() {  
   @Override 
      public boolean filter(Event value) throws Exception { 
   } 
});

これは、新しいパターン状態と、前のパターンを渡すために必要な一致イベントを追加するために使用されます。

Pattern<Event, ?> next = start.next("next");

に続く

これは、新しいパターン状態を追加するために使用されますが、ここでは、2つの一致するイベントによって他のイベントが発生する可能性があります。

Pattern<Event, ?> followedBy = start.followedBy("next");

ジェリー

ApacheFlinkのGraphAPIはGellyです。Gellyは、一連のメソッドとユーティリティを使用してFlinkアプリケーションでグラフ分析を実行するために使用されます。Gellyで分散方式でApacheFlink APIを使用して、巨大なグラフを分析できます。同じ目的でApacheGiraphのような他のグラフライブラリもありますが、GellyはApache Flinkの上で使用されるため、単一のAPIを使用します。これは、開発と運用の観点から非常に役立ちます。

Apache FlinkAPI-Gellyを使用して例を実行してみましょう。

まず、2つのGellyjarファイルをApacheFlinkのoptディレクトリからそのlibディレクトリにコピーする必要があります。次に、flink-gelly-examplesjarを実行します。

cp opt/flink-gelly* lib/ 
./bin/flink run examples/gelly/flink-gelly-examples_*.jar

PageRankの例を実行してみましょう。

PageRankは、頂点ごとのスコアを計算します。これは、エッジ内で送信されたPageRankスコアの合計です。各頂点のスコアは、アウトエッジ間で均等に分割されます。高スコアの頂点は、他の高スコアの頂点によってリンクされています。

結果には、頂点IDとPageRankスコアが含まれます。

usage: flink run examples/flink-gelly-examples_<version>.jar --algorithm PageRank [algorithm options] --input <input> [input options] --output <output> [output options] 

./bin/flink run examples/gelly/flink-gelly-examples_*.jar --algorithm PageRank --input CycleGraph --vertex_count 2 --output Print