Migrate NiFi state and custom components
Provides steps for migrating NiFi state and custom components.
Copy local state
The state-management.xml file contains a
local-provider
value with a directory path. Copy the contents of local
state directory from each source NiFi node to a node in the
destination cluster. For example: source Node 1 → destination Node 1, source Node 2 →
destination Node 2, …, source Node N → destination Node N.
The default state directory path in CFM 2.1.4 is /var/lib/nifi/state.
Copy cluster state
The state-management.xml file contains a
cluster-provider
value with ZooKeeper configuration. Use the ZooKeeper
Migrator in the NiFi Toolkit to migrate NiFi ZooKeeper content from the source cluster to
the destination.
- Export the NiFi component data from the source ZooKeeper:
./zk-migrator.sh -r -z sourceHostname:sourceClientPort/sourceRootPath/components -f /path/to/export/zk-source-data.json
- Migrate the source ZooKeeper data to the destination ZooKeeper:
./zk-migrator.sh -s -z destinationHostname:destinationClientPort/destinationRootPath/components -f /path/to/export/zk-source-data.json
For more information on the ZooKeeper Migrator, see Using the Apache NiFi Toolkit.
Manage custom components
- In Cloudera Manager:
- Find the NiFi configuration property “NiFi Node Advanced Configuration Snippet (Safety Valve) for staging/nifi.properties.xml”
- Click “+” to add a snippet.
- For the Name, enter:
nifi.nar.library.directory.custom
- For the Value, enter:
/opt/configuration_resources/custom_lib
- Enter a description.
For example:
- On every destination NiFi cluster node, copy any custom NiFi NARs to the directory path specified by the Value field.
After you finish
When you have finished migrating NiFi state and any custom components, proceed by migrating the NiFi Registry data storage.