अपाचे NiFi - निगरानी
Apache NiFi में, सिस्टम के विभिन्न आँकड़ों की निगरानी करने के कई तरीके हैं जैसे त्रुटियां, मेमोरी उपयोग, सीपीयू उपयोग, डेटा फ़्लो आँकड़े, आदि। हम इस ट्यूटोरियल में सबसे लोकप्रिय लोगों के बारे में चर्चा करेंगे।
बिल्ट मॉनिटरिंग में
इस खंड में, हम Apache NiFi में निर्मित निगरानी के बारे में अधिक जानेंगे।
बुलेटिन बोर्ड
बुलेटिन बोर्ड वास्तविक समय में NiFi प्रोसेसर द्वारा उत्पन्न नवीनतम ERROR और चेतावनी दिखाता है। बुलेटिन बोर्ड तक पहुंचने के लिए, एक उपयोगकर्ता को दाहिने हाथ के ड्रॉप डाउन मेनू पर जाना होगा और बुलेटिन बोर्ड विकल्प का चयन करना होगा। यह स्वचालित रूप से ताज़ा हो जाता है और एक उपयोगकर्ता इसे अक्षम भी कर सकता है। एक उपयोगकर्ता त्रुटि को डबल-क्लिक करके वास्तविक प्रोसेसर पर भी नेविगेट कर सकता है। एक उपयोगकर्ता निम्नलिखित के साथ काम करके बुलेटिन को फ़िल्टर कर सकता है -
- संदेश द्वारा
- नाम से
- आईडी से
- समूह आईडी द्वारा
डेटा प्रोविज़न यूआई
किसी भी विशिष्ट प्रोसेसर या पूरे NiFi पर होने वाली घटनाओं की निगरानी करने के लिए, उपयोगकर्ता बुलेटिन बोर्ड के समान मेनू से डेटा प्रोविज़न को एक्सेस कर सकता है। एक उपयोगकर्ता निम्नलिखित क्षेत्रों के साथ काम करके डेटा प्रोवेंस रिपॉजिटरी में घटनाओं को फ़िल्टर कर सकता है -
- घटक नाम से
- घटक प्रकार द्वारा
- प्रकार से
NiFi सारांश UI
Apache NiFi सारांश को बुलेटिन बोर्ड के समान मेनू से भी एक्सेस किया जा सकता है। इस UI में उस विशेष NiFi उदाहरण या क्लस्टर के सभी घटकों के बारे में जानकारी है। उन्हें नाम से, प्रकार से या यूआरआई द्वारा फ़िल्टर किया जा सकता है। विभिन्न घटक प्रकारों के लिए अलग-अलग टैब हैं। निम्नलिखित घटक हैं, जिन्हें NiFi सारांश UI में देखा जा सकता है -
- Processors
- इनपुट पोर्ट
- आउटपुट पोर्ट
- दूरस्थ प्रक्रिया समूह
- Connections
- प्रक्रिया समूह
इस UI में, JVM आँकड़ों की जाँच करने के लिए सिस्टम डायग्नोस्टिक्स के नीचे दाहिने हाथ की ओर एक लिंक है।
रिपोर्टिंग कार्य
Apache NiFi, बाह्य निगरानी प्रणाली जैसे Ambari, Grafana, आदि का समर्थन करने के लिए कई रिपोर्टिंग कार्य प्रदान करता है। एक डेवलपर एक कस्टम रिपोर्टिंग कार्य बना सकता है या इनबिल्ट करने वालों को बाहरी मॉनिटरिंग सिस्टमों को NiFi के मैट्रिक्स भेजने के लिए कॉन्फ़िगर कर सकता है। निफ्टी 1.7.1 द्वारा दिए गए रिपोर्टिंग कार्यों की सूची नीचे दी गई तालिका में दी गई है।
क्र.सं. | रिपोर्टिंग कार्य का नाम | विवरण |
---|---|---|
1 | AmbariReportingTask | NiFi के लिए अंबरी मेट्रिक्स सर्विस सेटअप करना। |
2 | ControllerStatusReportingTask | अंतिम 5 मिनट के लिए NiFi सारांश UI से सूचना रिपोर्ट करने के लिए। |
3 | MonitorDiskUsage | किसी विशिष्ट निर्देशिका के डिस्क उपयोग के बारे में रिपोर्ट और चेतावनी देने के लिए। |
4 | MonitorMemory | JVM के जावा मेमोरी पूल में उपयोग किए जाने वाले जावा हीप की मात्रा की निगरानी करने के लिए। |
5 | SiteToSiteBulletinReportingTask | साइट से साइट प्रोटोकॉल का उपयोग करके बुलेटिन में त्रुटियों और चेतावनी की रिपोर्ट करना। |
6 | SiteToSiteProvenanceReportingTask | साइट से साइट प्रोटोकॉल का उपयोग करके NiFi डेटा प्रोवेंस की घटनाओं की रिपोर्ट करना। |
NiFi API
एक API नाम सिस्टम डायग्नोस्टिक्स है, जिसका उपयोग किसी भी विकसित विकसित अनुप्रयोग में NiFI आँकड़ों की निगरानी के लिए किया जा सकता है। हमें डाकिया में एपीआई की जाँच करें।
निवेदन
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"
}
}
}
}