 
- Apache NiFi - Home
- Apache NiFi - Introduction
- Apache NiFi - Basic Concepts
- Apache NiFi - Environment Setup
- Apache NiFi - User Interface
- Apache NiFi - Processors
- Apache NiFi - Processors Categorization
- Apache NiFi - Processors Relationship
- Apache NiFi - FlowFile
- Apache NiFi - Queues
- Apache NiFi - Process Groups
- Apache NiFi - Labels
- Apache NiFi - Configuration
- Apache NiFi - Administration
- Apache NiFi - Creating Flows
- Apache NiFi - Templates
- Apache NiFi - API
- Apache NiFi - Data Provenance
- Apache NiFi - Monitoring
- Apache NiFi - Upgrade
- Apache NiFi - Remote Process Group
- Apache NiFi - Controller Settings
- Apache NiFi - Reporting Task
- Apache NiFi - Custom Processor
- Apache NiFi - Custom Controllers Service
- Apache NiFi - Logging
- Apache NiFi Useful Resources
- Apache NiFi - Quick Guide
- Apache NiFi - Useful Resources
- Apache NiFi - Discussion
Apache NiFi - Monitoring
In Apache NiFi, there are multiple ways to monitor the different statistics of the system like errors, memory usage, CPU usage, Data Flow statistics, etc. We will discuss the most popular ones in this tutorial.
In built Monitoring
In this section, we will learn more about in built monitoring in Apache NiFi.
Bulletin Board
The bulletin board shows the latest ERROR and WARNING getting generated by NiFi processors in real time. To access the bulletin board, a user will have to go the right hand drop down menu and select the Bulletin Board option. It refreshes automatically and a user can disable it also. A user can also navigate to the actual processor by double-clicking the error. A user can also filter the bulletins by working out with the following −
- by message
- by name
- by id
- by group id
Data provenance UI
To monitor the Events occurring on any specific processor or throughout NiFi, a user can access the Data provenance from the same menu as the bulletin board. A user can also filter the events in data provenance repository by working out with the following fields −
- by component name
- by component type
- by type
NiFi Summary UI
Apache NiFi summary also can be accessed from the same menu as the bulletin board. This UI contains information about all the components of that particular NiFi instance or cluster. They can be filtered by name, by type or by URI. There are different tabs for different component types. Following are the components, which can be monitored in the NiFi summary UI −
- Processors
- Input ports
- Output ports
- Remote process groups
- Connections
- Process groups
In this UI, there is a link at the bottom right hand side named system diagnostics to check the JVM statistics.
Reporting Tasks
Apache NiFi provides multiple reporting tasks to support external monitoring systems like Ambari, Grafana, etc. A developer can create a custom reporting task or can configure the inbuilt ones to send the metrics of NiFi to the externals monitoring systems. The following table lists down the reporting tasks offered by NiFi 1.7.1.
| S.No. | Reporting Task Name | Description | 
|---|---|---|
| 1 | AmbariReportingTask | To setup Ambari Metrics Service for NiFi. | 
| 2 | ControllerStatusReportingTask | To report the information from the NiFi summary UI for the last 5 minute. | 
| 3 | MonitorDiskUsage | To report and warn about the disk usage of a specific directory. | 
| 4 | MonitorMemory | To monitor the amount of Java Heap used in a Java Memory pool of JVM. | 
| 5 | SiteToSiteBulletinReportingTask | To report the errors and warning in bulletins using Site to Site protocol. | 
| 6 | SiteToSiteProvenanceReportingTask | To report the NiFi Data Provenance events using Site to Site protocol. | 
NiFi API
There is an API named system diagnostics, which can be used to monitor the NiFI stats in any custom developed application. Let us check the API in postman.
Request
https://localhost:8443/nifi-api/system-diagnostics
Response
{
  "systemDiagnostics": {
    "aggregateSnapshot": {
      "totalNonHeap": "180.88 MB",
      "totalNonHeapBytes": 189661184,
      "usedNonHeap": "177.54 MB",
      "usedNonHeapBytes": 186167184,
      "freeNonHeap": "3.33 MB",
      "freeNonHeapBytes": 3494000,
      "maxNonHeap": "-1 bytes",
      "maxNonHeapBytes": -1,
      "totalHeap": "1,024 MB",
      "totalHeapBytes": 1073741824,
      "usedHeap": "391.02 MB",
      "usedHeapBytes": 410012632,
      "freeHeap": "632.98 MB",
      "freeHeapBytes": 663729192,
      "maxHeap": "1,024 MB",
      "maxHeapBytes": 1073741824,
      "heapUtilization": "38.0%",
      "availableProcessors": 12,
      "processorLoadAverage": -1,
      "totalThreads": 95,
      "daemonThreads": 43,
      "uptime": "02:28:44.089",
      "flowFileRepositoryStorageUsage": {
        "freeSpace": "189.04 GB",
        "totalSpace": "200 GB",
        "usedSpace": "10.96 GB",
        "freeSpaceBytes": 202983182336,
        "totalSpaceBytes": 214747312128,
        "usedSpaceBytes": 11764129792,
        "utilization": "5.0%"
      },
      "contentRepositoryStorageUsage": [
        {
          "identifier": "default",
          "freeSpace": "189.04 GB",
          "totalSpace": "200 GB",
          "usedSpace": "10.96 GB",
          "freeSpaceBytes": 202983182336,
          "totalSpaceBytes": 214747312128,
          "usedSpaceBytes": 11764129792,
          "utilization": "5.0%"
        }
      ],
      "provenanceRepositoryStorageUsage": [
        {
          "identifier": "default",
          "freeSpace": "189.04 GB",
          "totalSpace": "200 GB",
          "usedSpace": "10.96 GB",
          "freeSpaceBytes": 202983182336,
          "totalSpaceBytes": 214747312128,
          "usedSpaceBytes": 11764129792,
          "utilization": "5.0%"
        }
      ],
      "garbageCollection": [
        {
          "name": "G1 Young Generation",
          "collectionCount": 13,
          "collectionTime": "00:00:00.278",
          "collectionMillis": 278
        },
        {
          "name": "G1 Concurrent GC",
          "collectionCount": 8,
          "collectionTime": "00:00:00.015",
          "collectionMillis": 15
        },
        {
          "name": "G1 Old Generation",
          "collectionCount": 0,
          "collectionTime": "00:00:00.000",
          "collectionMillis": 0
        }
      ],
      "statsLastRefreshed": "21:15:57 IST",
      "versionInfo": {
        "niFiVersion": "2.5.0",
        "javaVendor": "Oracle Corporation",
        "javaVersion": "24.0.1",
        "osName": "Windows 11",
        "osVersion": "10.0",
        "osArchitecture": "amd64",
        "buildTag": "rel/nifi-2.5.0"
      }
    }
  }
}