Apache NiFi - Pemantauan

Di Apache NiFi, ada beberapa cara untuk memantau statistik yang berbeda dari sistem seperti kesalahan, penggunaan memori, penggunaan CPU, statistik Aliran Data, dll. Kita akan membahas yang paling populer dalam tutorial ini.

Pemantauan bawaan

Di bagian ini, kita akan mempelajari lebih lanjut tentang pemantauan bawaan di Apache NiFi.

Papan pengumuman

Papan buletin menunjukkan ERROR dan PERINGATAN terbaru yang dihasilkan oleh prosesor NiFi secara real time. Untuk mengakses papan buletin, pengguna harus pergi ke menu drop down sebelah kanan dan memilih opsi Papan Buletin. Ini menyegarkan secara otomatis dan pengguna juga dapat menonaktifkannya. Seorang pengguna juga dapat menavigasi ke prosesor sebenarnya dengan mengklik dua kali kesalahan tersebut. Seorang pengguna juga dapat memfilter buletin dengan mengerjakan yang berikut -

  • melalui pesan
  • dengan nama
  • menurut id
  • menurut id grup

UI asal data

Untuk memantau Peristiwa yang terjadi pada prosesor tertentu atau di seluruh NiFi, pengguna dapat mengakses asal Data dari menu yang sama dengan papan buletin. Seorang pengguna juga dapat memfilter kejadian dalam repositori asal data dengan bekerja dengan bidang berikut -

  • dengan nama komponen
  • menurut jenis komponen
  • menurut jenis

UI Ringkasan NiFi

Ringkasan Apache NiFi juga dapat diakses dari menu yang sama dengan papan buletin. UI ini berisi informasi tentang semua komponen dari instance atau cluster NiFi tertentu. Mereka dapat difilter menurut nama, jenis atau URI. Ada tab berbeda untuk jenis komponen berbeda. Berikut adalah komponen, yang dapat dipantau di UI ringkasan NiFi -

  • Processors
  • Port masukan
  • Port keluaran
  • Grup proses jarak jauh
  • Connections
  • Kelompok proses

Di UI ini, ada tautan di sisi kanan bawah bernama diagnostik sistem untuk memeriksa statistik JVM.

Melaporkan Tugas

Apache NiFi menyediakan banyak tugas pelaporan untuk mendukung sistem pemantauan eksternal seperti Ambari, Grafana, dll. Seorang pengembang dapat membuat tugas pelaporan khusus atau dapat mengonfigurasi tugas bawaan untuk mengirim metrik NiFi ke sistem pemantauan eksternal. Tabel berikut mencantumkan tugas pelaporan yang ditawarkan oleh NiFi 1.7.1.

S.No. Nama Tugas Pelaporan Deskripsi
1 AmbariReportingTask Untuk mengatur Ambari Metrics Service untuk NiFi.
2 ControllerStatusReportingTask Untuk melaporkan informasi dari ringkasan UI NiFi selama 5 menit terakhir.
3 MonitorDiskUsage Untuk melaporkan dan memperingatkan tentang penggunaan disk dari direktori tertentu.
4 MonitorMemory Untuk memantau jumlah Java Heap yang digunakan dalam pool Java Memory JVM.
5 SiteToSiteBulletinReportingTask Untuk melaporkan kesalahan dan peringatan di buletin menggunakan protokol Situs ke Situs.
6 SiteToSiteProvenanceReportingTask Untuk melaporkan kejadian NiFi Data Provenance menggunakan protokol Site to Site.

API NiFi

Ada API bernama diagnostik sistem, yang dapat digunakan untuk memantau statistik NiFI dalam aplikasi yang dikembangkan khusus. Mari kita periksa API di tukang pos.

Permintaan

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

Tanggapan

{
   "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"
         }
      }
   }
}