अपाचे 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"
         }
      }
   }
}