FetchFile

Description:

Reads the contents of a file from disk and streams it into the contents of an incoming FlowFile. Once this is done, the file is optionally moved elsewhere or deleted to help keep the file system organized.

Tags:

local, files, filesystem, ingest, ingress, get, source, input, fetch

Properties:

In the list below, the names of required properties appear in bold. Any other properties (not in bold) are considered optional. The table also indicates any default values, and whether a property supports the NiFi Expression Language.

Display NameAPI NameDefault ValueAllowable ValuesDescription
File to FetchFile to Fetch${absolute.path}/${filename}The fully-qualified filename of the file to fetch from the file system
Supports Expression Language: true (will be evaluated using flow file attributes and Environment variables)
Completion StrategyCompletion StrategyNone
  • None Leave the file as-is
  • Move File Moves the file to the directory specified by the <Move Destination Directory> property
  • Delete File Deletes the original file from the file system
Specifies what to do with the original file on the file system once it has been pulled into NiFi
Move Destination DirectoryMove Destination DirectoryThe directory to the move the original file to once it has been fetched from the file system. This property is ignored unless the Completion Strategy is set to "Move File". If the directory does not exist, it will be created.
Supports Expression Language: true (will be evaluated using flow file attributes and Environment variables)
Move Conflict StrategyMove Conflict StrategyRename
  • Rename The existing destination file should remain intact. The newly ingested file should be moved to the destination directory but be renamed to a random filename
  • Replace File The newly ingested file should replace the existing file in the Destination Directory
  • Keep Existing The existing file should in the Destination Directory should stay intact and the newly ingested file should be deleted
  • Fail The existing destination file should remain intact and the incoming FlowFile should be routed to failure
If Completion Strategy is set to Move File and a file already exists in the destination directory with the same name, this property specifies how that naming conflict should be resolved
Log level when file not foundLog level when file not foundERROR
  • TRACE
  • DEBUG
  • INFO
  • WARN
  • ERROR
  • FATAL
  • NONE
Log level to use in case the file does not exist when the processor is triggered
Log level when permission deniedLog level when permission deniedERROR
  • TRACE
  • DEBUG
  • INFO
  • WARN
  • ERROR
  • FATAL
  • NONE
Log level to use in case user nifi does not have sufficient permissions to read the file

Relationships:

NameDescription
successAny FlowFile that is successfully fetched from the file system will be transferred to this Relationship.
not.foundAny FlowFile that could not be fetched from the file system because the file could not be found will be transferred to this Relationship.
permission.deniedAny FlowFile that could not be fetched from the file system due to the user running NiFi not having sufficient permissions will be transferred to this Relationship.
failureAny FlowFile that could not be fetched from the file system for any reason other than insufficient permissions or the file not existing will be transferred to this Relationship.

Reads Attributes:

None specified.

Writes Attributes:

None specified.

State management:

This component does not store state.

Restricted:

Required PermissionExplanation
read filesystemProvides operator the ability to read from any file that NiFi has access to.
write filesystemProvides operator the ability to delete any file that NiFi has access to.

Input requirement:

This component requires an incoming relationship.

Example Use Cases Involving Other Components:

Use Case:

Ingest all files from a directory into NiFi

Keywords:

local, files, filesystem, ingest, ingress, get, source, input, fetch

Components involved:

Component Type: org.apache.nifi.processors.standard.ListFile

Configuration:

Configure the "Input Directory" property to point to the directory that you want to ingest files from.

Set the "Input Directory Location" property to "Local"

Optionally, set "Minimum File Age" to a small value such as "1 min" to avoid ingesting files that are still being written to.

Connect the 'success' Relationship to the FetchFile processor.



Component Type: org.apache.nifi.processors.standard.FetchFile

Configuration:

Set the "File to Fetch" property to ${absolute.path}/${filename}

Set the "Completion Strategy" property to None





Use Case:

Ingest specific files from a directory into NiFi, filtering on filename

Keywords:

local, files, filesystem, ingest, ingress, get, source, input, fetch, filter

Components involved:

Component Type: org.apache.nifi.processors.standard.ListFile

Configuration:

Configure the "Input Directory" property to point to the directory that you want to ingest files from.

Set the "Input Directory Location" property to "Local"

Set the "File Filter" property to a Regular Expression that matches the filename (without path) of the files that you want to ingest. For example, to ingest all .jpg files, set the value to .*\.jpg

Optionally, set "Minimum File Age" to a small value such as "1 min" to avoid ingesting files that are still being written to.

Connect the 'success' Relationship to the FetchFile processor.



Component Type: org.apache.nifi.processors.standard.FetchFile

Configuration:

Set the "File to Fetch" property to ${absolute.path}/${filename}

Set the "Completion Strategy" property to None





System Resource Considerations:

None specified.

See Also:

GetFile, PutFile, ListFile