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