ApacheNiFi-監視

Apache NiFiでは、エラー、メモリ使用量、CPU使用率、データフロー統計など、システムのさまざまな統計を監視する方法が複数あります。このチュートリアルでは、最も一般的な方法について説明します。

組み込みの監視

このセクションでは、ApacheNiFiの組み込み監視について詳しく学習します。

掲示板

掲示板には、NiFiプロセッサによって生成される最新のエラーと警告がリアルタイムで表示されます。掲示板にアクセスするには、ユーザーは右側のドロップダウンメニューに移動して[掲示板]オプションを選択する必要があります。自動的に更新され、ユーザーは無効にすることもできます。ユーザーは、エラーをダブルクリックして実際のプロセッサに移動することもできます。ユーザーは、次の方法でセキュリティ情報をフィルタリングすることもできます。

  • メッセージで
  • 名前で
  • ID別
  • グループID別

データ来歴UI

特定のプロセッサまたはNiFi全体で発生するイベントを監視するために、ユーザーは掲示板と同じメニューからデータの出所にアクセスできます。ユーザーは、次のフィールドを使用して、データ来歴リポジトリ内のイベントをフィルタリングすることもできます。

  • コンポーネント名別
  • コンポーネントタイプ別
  • タイプ別

NiFiサマリーUI

Apache NiFiの概要には、掲示板と同じメニューからアクセスすることもできます。このUIには、その特定のNiFiインスタンスまたはクラスターのすべてのコンポーネントに関する情報が含まれています。それらは、名前、タイプ、またはURIでフィルタリングできます。コンポーネントタイプごとに異なるタブがあります。以下は、NiFiサマリーUIで監視できるコンポーネントです。

  • Processors
  • 入力ポート
  • 出力ポート
  • リモートプロセスグループ
  • Connections
  • プロセスグループ

このUIでは、JVM統計をチェックするためのシステム診断という名前のリンクが右下にあります。

レポートタスク

Apache NiFiは、Ambari、Grafanaなどの外部監視システムをサポートする複数のレポートタスクを提供します。開発者は、カスタムレポートタスクを作成するか、NiFiのメトリックを外部監視システムに送信するように組み込みのレポートタスクを構成できます。次の表に、NiFi1.7.1が提供するレポートタスクを示します。

S.No. レポートタスク名 説明
1 AmbariReportingTask NiFi用のAmbariMetricsServiceをセットアップします。
2 ControllerStatusReportingTask 過去5分間のNiFiサマリーUIからの情報を報告します。
3 MonitorDiskUsage 特定のディレクトリのディスク使用量について報告および警告するため。
4 MonitorMemory JVMのJavaメモリプールで使用されるJavaヒープの量を監視します。
5 SiteToSiteBulletinReportingTask サイト間プロトコルを使用して、セキュリティ情報のエラーと警告を報告します。
6 SiteToSiteProvenanceReportingTask サイト間プロトコルを使用してNiFiデータ来歴イベントを報告します。

NiFi API

システム診断という名前のAPIがあり、カスタム開発されたアプリケーションでNiFI統計を監視するために使用できます。postmanでAPIを確認しましょう。

リクエスト

http://localhost:8080/nifi-api/system-diagnostics

応答

{
   "systemDiagnostics": {
      "aggregateSnapshot": {
         "totalNonHeap": "183.89 MB",
         "totalNonHeapBytes": 192819200,
         "usedNonHeap": "173.47 MB",
         "usedNonHeapBytes": 181894560,
         "freeNonHeap": "10.42 MB",
         "freeNonHeapBytes": 10924640,
         "maxNonHeap": "-1 bytes",
         "maxNonHeapBytes": -1,
         "totalHeap": "512 MB",
         "totalHeapBytes": 536870912,
         "usedHeap": "273.37 MB",
         "usedHeapBytes": 286652264,
         "freeHeap": "238.63 MB",
         "freeHeapBytes": 250218648,
         "maxHeap": "512 MB",
         "maxHeapBytes": 536870912,
         "heapUtilization": "53.0%",
         "availableProcessors": 4,
         "processorLoadAverage": -1,
         "totalThreads": 71,
         "daemonThreads": 31,
         "uptime": "17:30:35.277",
         "flowFileRepositoryStorageUsage": {
            "freeSpace": "286.93 GB",
            "totalSpace": "464.78 GB",
            "usedSpace": "177.85 GB",
            "freeSpaceBytes": 308090789888,
            "totalSpaceBytes": 499057160192,
            "usedSpaceBytes": 190966370304,
            "utilization": "38.0%"
         },
         "contentRepositoryStorageUsage": [
            {
               "identifier": "default",
               "freeSpace": "286.93 GB",
               "totalSpace": "464.78 GB",
               "usedSpace": "177.85 GB",
               "freeSpaceBytes": 308090789888,
               "totalSpaceBytes": 499057160192,
               "usedSpaceBytes": 190966370304,
               "utilization": "38.0%"
            }
         ],
         "provenanceRepositoryStorageUsage": [
            {
               "identifier": "default",
               "freeSpace": "286.93 GB",
               "totalSpace": "464.78 GB",
               "usedSpace": "177.85 GB",
               "freeSpaceBytes": 308090789888,
               "totalSpaceBytes": 499057160192,
               "usedSpaceBytes": 190966370304,
               "utilization": "38.0%"
            }
         ],
         "garbageCollection": [
            {
               "name": "G1 Young Generation",
               "collectionCount": 344,
               "collectionTime": "00:00:06.239",
               "collectionMillis": 6239
            },
            {
               "name": "G1 Old Generation",
               "collectionCount": 0,
               "collectionTime": "00:00:00.000",
               "collectionMillis": 0
            }
         ],
         "statsLastRefreshed": "09:30:20 SGT",
         "versionInfo": {
            "niFiVersion": "1.7.1",
            "javaVendor": "Oracle Corporation",
            "javaVersion": "1.8.0_151",
            "osName": "Windows 7",
            "osVersion": "6.1",
            "osArchitecture": "amd64",
            "buildTag": "nifi-1.7.1-RC1",
            "buildTimestamp": "07/12/2018 12:54:43 SGT"
         }
      }
   }
}