Apache NiFi
Go to file
exceptionfactory e3ac4089c5
NIFI-13909 Refreshed and Streamlined Project README
Signed-off-by: Pierre Villard <pierre.villard.fr@gmail.com>

This closes #9426.
2024-10-21 14:17:01 +02:00
.github NIFI-13632: Updating content access. (#9221) 2024-09-06 09:12:38 -04:00
.mvn/wrapper NIFI-13899 Upgraded Maven from 3.9.8 to 3.9.9 2024-10-18 14:53:26 -07:00
c2 NIFI-13812 [MiNiFi][C2] Add component type into Agent Manifest Hash calculation 2024-10-01 08:48:54 +02:00
minifi NIFI-13894 Removed protected and additional keys properties 2024-10-17 14:28:04 -07:00
nifi-assembly NIFI-13644 Added GitLab Flow Registry Client (#9264) 2024-10-16 15:03:21 -05:00
nifi-bom NIFI-13804 Migrated to NiFi API 2.0.0 2024-09-26 04:54:24 -04:00
nifi-bootstrap NIFI-13813 Refactored NiFi Runtime Property Loading (#9322) 2024-10-09 11:16:42 -04:00
nifi-code-coverage NIFI-13895 Upgraded AWS SDK to 1.12.775 and 2.28.25 along with others (#9416) 2024-10-18 00:11:52 -05:00
nifi-commons NIFI-13890 Fixed referencing components for quoted parameter names (#9411) 2024-10-18 07:56:51 -05:00
nifi-dependency-check-maven NIFI-13515 Removed PutKudu and nifi-kudu-bundle 2024-07-05 11:22:44 -05:00
nifi-docker NIFI-13681 Aligned Cluster Docker Environment Variables with Properties (#9199) 2024-08-27 11:21:17 -05:00
nifi-docs NIFI-13893 Removed Outdated Encryption Configuration from Admin Guide 2024-10-17 14:29:51 -07:00
nifi-extension-bom NIFI-13886 Upgraded Spring from 6.1.13 to 6.1.14 and others 2024-10-17 18:04:51 +02:00
nifi-extension-bundles NIFI-13776 Updated CopyS3Object to Handle Files over 5 GB 2024-10-18 16:24:38 -07:00
nifi-framework-api NIFI-13795 Improve NAR Manager handling of dependent NARs (#9310) 2024-09-26 12:28:17 -05:00
nifi-framework-bundle NIFI-13898 Upgraded Lucene from 9.12.0 to 10.0.0 2024-10-18 14:54:27 -07:00
nifi-frontend NIFI-13901 Fixed Additional Details Section Title 2024-10-18 14:38:33 -07:00
nifi-manifest NIFI-13721: Migrating documentation into the NiFi UI (#9288) 2024-09-27 11:11:55 -04:00
nifi-maven-archetypes NIFI-13809 Upgraded Maven Archetype Plugin from 3.2.1 to 3.3.0 (#9318) 2024-09-26 16:31:45 -05:00
nifi-mock NIFI-13804 Migrated to NiFi API 2.0.0 2024-09-26 04:54:24 -04:00
nifi-registry NIFI-13895 Upgraded AWS SDK to 1.12.775 and 2.28.25 along with others (#9416) 2024-10-18 00:11:52 -05:00
nifi-server-api NIFI-12998 Restructured framework and extension modules 2024-04-26 12:12:48 -05:00
nifi-stateless NIFI-13721: Migrating documentation into the NiFi UI (#9288) 2024-09-27 11:11:55 -04:00
nifi-system-tests NIFI-13894 Removed protected and additional keys properties 2024-10-17 14:28:04 -07:00
nifi-toolkit NIFI-13895 Upgraded AWS SDK to 1.12.775 and 2.28.25 along with others (#9416) 2024-10-18 00:11:52 -05:00
.asf.yaml NIFI-13561 Enabled Jira Automatic Linking in GitHub (#9092) 2024-07-19 10:20:48 -04:00
.gitignore NIFI-12616 Added Processor Documentation Support for Python 2024-01-18 19:12:05 -06:00
KEYS NIFI-11832 Added OpenPGP Public Key for David Handermann 2023-07-19 16:57:42 -05:00
LICENSE NIFI-13313: Remove old UI (#8906) 2024-06-05 09:09:01 -04:00
NOTICE NIFI-13253 Corrected the discrepancies in the top level NOTICE file 2024-05-20 15:28:52 -05:00
README.md NIFI-13909 Refreshed and Streamlined Project README 2024-10-21 14:17:01 +02:00
SECURITY.md NIFI-12081 Removed HackerOne from Security Reporting Methods 2023-09-18 16:01:29 -05:00
checkstyle.xml NIFI-13238 Added Checkstyle rules for whitespace 2024-05-15 06:41:19 -05:00
codecov.yml NIFI-12192 Added Codecov Reporting with JaCoCo 2023-11-08 19:49:51 +00:00
doap.rdf ASF required doap file entry 2023-09-05 09:56:29 -07:00
mvnw NIFI-13300 Upgraded Maven from 3.9.6 to 3.9.7 2024-05-28 08:52:45 -05:00
mvnw.cmd NIFI-13300 Upgraded Maven from 3.9.6 to 3.9.7 2024-05-28 08:52:45 -05:00
pom.xml NIFI-13895 Upgraded AWS SDK to 1.12.775 and 2.28.25 along with others (#9416) 2024-10-18 00:11:52 -05:00

README.md

Apache NiFi

Apache NiFi

Status

ci-workflow system-tests integration-tests docker-tests code-coverage codecov

Resources

NiFi API NiFi NAR Maven Plugin NiFi Framework NiFI Docker Pulls License NiFi API Javadoc

Contacts

Track Issues Chat on Slack Contact Developers Contact Users

Community

Join Slack Community Follow on LinkedIn Follow on X

Features

Apache NiFi is an easy to use, powerful, and reliable system to process and distribute data.

NiFi automates cybersecurity, observability, event streams, and generative AI data pipelines and distribution for thousands of companies worldwide across every industry.

  • Browser User Interface
    • Seamless experience for design, control, and monitoring
    • Runtime management and versioned pipelines
    • Secure by default with HTTPS
  • Scalable Processing
    • Configurable prioritization for throughput and latency
    • Guaranteed delivery with retry and backoff strategies
    • Horizontal scaling with clustering
  • Provenance Tracking
    • Searchable history with configurable attributes
    • Graph data lineage from source to destination
    • Metadata and content for each processing decision
  • Extensible Design
    • Plugin interface for Processors and Controller Services
    • Support for Processors in native Python
    • REST API for orchestration and monitoring
  • Secure Configuration
    • Single sign-on with OpenID Connect or SAML 2
    • Flexible authorization policies for role-based access
    • Encrypted communication with TLS and SFTP

Requirements

NiFi supports modern operating systems and requires recent language versions for developing and running the application.

Platform Requirements

  • Java 21

Optional Dependencies

  • Python 3.10 or higher

Projects

The source repository includes several component projects.

Please review individual project documentation for additional details.

Getting Started

Project guides provide extensive documentation for installing and extending the application.

Developing

NiFi uses the Maven Wrapper for project development. The Maven Wrapper provides shell scripts that download and cache a selected version of Apache Maven for running build commands.

Developing on Microsoft Windows requires using mvnw.cmd instead of mvnw to run Maven commands.

Building

Run the following command to build project modules using parallel execution:

./mvnw install -T1C

Run the following command to build project modules using parallel execution with static analysis to confirm compliance with code and licensing requirements:

./mvnw install -T1C -P contrib-check

Run the following command to build the application binaries without building other optional modules:

./mvnw install -T1C -am -pl :nifi-assembly

Binaries

The nifi-assembly module contains the binary distribution.

ls nifi-assembly/target/nifi-*-bin.zip

The nifi-assembly module includes the binary distribution in a directory for local development and testing.

cd nifi-assembly/target/nifi-*-bin/nifi-*/

Running

NiFi provides shell scripts for starting and stopping the system.

Running on Microsoft Windows requires using nifi.cmd instead of nifi.sh for system commands.

Starting

Run the following command to start NiFi from the distribution directory:

./bin/nifi.sh start

Accessing

The default configuration generates a random username and password on startup. NiFi writes the generated credentials to the application log located in logs/nifi-app.log under the NiFi installation directory.

The following command can be used to find the generated credentials on operating systems with grep installed:

grep Generated logs/nifi-app*log

NiFi logs the generated credentials as follows:

Generated Username [USERNAME]
Generated Password [PASSWORD]

The USERNAME will be a random UUID composed of 36 characters. The PASSWORD will be a random string.

The username and password can be replaced with custom credentials using the following command:

./bin/nifi.sh set-single-user-credentials <username> <password>

NiFi defaults to running on the localhost address with HTTPS on port 8443 at the following URL:

https://localhost:8443/nifi

Browsers will display a warning message indicating a potential security risk due to the self-signed certificate generated during initialization. Production deployments should provision a certificate from a trusted certificate authority and update the NiFi keystore and truststore configuration.

License

Except as otherwise noted this software is licensed under the Apache License, Version 2.0

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

https://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.

Export Control

This distribution includes cryptographic software. The country in which you currently reside may have restrictions on the import, possession, use, and/or re-export to another country, of encryption software. BEFORE using any encryption software, please check your country's laws, regulations and policies concerning the import, possession, or use, and re-export of encryption software, to see if this is permitted. See https://www.wassenaar.org for more information.

The U.S. Government Department of Commerce, Bureau of Industry and Security (BIS), has classified this software as Export Commodity Control Number (ECCN) 5D002.C.1, which includes information security software using or performing cryptographic functions with asymmetric algorithms. The form and manner of this Apache Software Foundation distribution makes it eligible for export under the License Exception ENC Technology Software Unrestricted (TSU) exception (see the BIS Export Administration Regulations, Section 740.13) for both object code and source code.

The following provides more details on the included cryptographic software:

Apache NiFi uses the following libraries and frameworks for encrypted communication and storage of sensitive information: