Claude-skill-registry apache-nifi-registry
Expert guidance for Apache NiFi Registry including flow versioning, buckets, Git integration, security, and registry client configuration. Use this when working with flow version control and registry management.
install
source · Clone the upstream repo
git clone https://github.com/majiayu000/claude-skill-registry
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/majiayu000/claude-skill-registry "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/data/apache-nifi-registry" ~/.claude/skills/majiayu000-claude-skill-registry-apache-nifi-registry && rm -rf "$T"
manifest:
skills/data/apache-nifi-registry/SKILL.mdsafety · automated scan (low risk)
This is a pattern-based risk scan, not a security review. Our crawler flagged:
- makes HTTP requests (curl)
Always read a skill's source content before installing. Patterns alone don't mean the skill is malicious — but they warrant attention.
source content
Apache NiFi Registry Expert Skill
You are an expert in Apache NiFi Registry, a central location for storing and managing shared resources like versioned flows.
Core Concepts
Architecture
- Buckets: Containers for organizing versioned items
- Versioned Flows: Snapshots of NiFi process groups
- Flow Versions: Individual versions within a flow
- Registry Clients: Connections from NiFi to Registry
Key Features
Version Control
- Store and manage NiFi flow versions
- Track changes with metadata and comments
- Compare versions side-by-side
- Import/export flows between environments
Storage Backends
- File System: Default local storage
- Git: Store flows in Git repositories
- Database: Store in relational database (PostgreSQL, MySQL)
Configuration
registry.properties
# Web UI nifi.registry.web.http.host=0.0.0.0 nifi.registry.web.http.port=18080 # Flow Persistence nifi.registry.flow.storage.directory=./flow_storage # Git Flow Persistence Provider nifi.registry.provider.flow.git.implementation=org.apache.nifi.registry.provider.flow.git.GitFlowPersistenceProvider nifi.registry.provider.flow.git.Flow Storage Directory=./flow_storage
Git Integration
<!-- providers.xml --> <flowPersistenceProvider> <class>org.apache.nifi.registry.provider.flow.git.GitFlowPersistenceProvider</class> <property name="Flow Storage Directory">./flow_storage</property> <property name="Remote To Push">origin</property> <property name="Remote Access User">git-user</property> <property name="Remote Access Password">password</property> </flowPersistenceProvider>
Docker Deployment
Standalone Registry
services: nifi-registry: image: apache/nifi-registry:latest ports: - "18080:18080" environment: - LOG_LEVEL=INFO volumes: - ./nifi-registry/database:/opt/nifi-registry/nifi-registry-current/database - ./nifi-registry/flow_storage:/opt/nifi-registry/nifi-registry-current/flow_storage - ./nifi-registry/conf:/opt/nifi-registry/nifi-registry-current/conf
With Git Backend
services: nifi-registry: image: apache/nifi-registry:latest ports: - "18080:18080" volumes: - ./nifi-registry/flow_storage:/opt/nifi-registry/nifi-registry-current/flow_storage - ./nifi-registry/conf/providers.xml:/opt/nifi-registry/nifi-registry-current/conf/providers.xml environment: - NIFI_REGISTRY_FLOW_PROVIDER=git - NIFI_REGISTRY_GIT_REMOTE=https://github.com/org/nifi-flows.git - NIFI_REGISTRY_GIT_USER=git-user - NIFI_REGISTRY_GIT_PASSWORD=token
Usage Workflow
Connect NiFi to Registry
-
Add Registry Client (NiFi Controller Settings)
Name: Dev Registry URL: http://nifi-registry:18080 -
Create Bucket (in Registry UI)
Bucket Name: Production Flows Description: Versioned production data flows -
Version Control a Flow (in NiFi)
- Right-click Process Group
- Version → Start version control
- Select Registry, Bucket, Flow name
- Add version comment
- Click Save
Version Management
# Commit Changes (NiFi UI) Right-click Process Group → Version → Commit local changes # View Change Log Right-click Process Group → Version → Show local changes # Revert Changes Right-click Process Group → Version → Revert local changes # Change Version Right-click Process Group → Version → Change version
Best Practices
Bucket Organization
Buckets by Environment: ├── Development ├── Testing ├── Staging └── Production OR by Domain: ├── Data Ingestion ├── ETL Pipelines ├── Analytics └── Data Distribution
Versioning Strategy
- Commit frequently with meaningful messages
- Tag stable releases (v1.0.0, v1.1.0)
- Use branching for experimental changes (if using Git backend)
- Document breaking changes in commit messages
- Test in lower environments before promoting
Naming Conventions
Flow Names: - product-ingestion-flow - customer-etl-pipeline - sensor-data-aggregation Version Comments: - "feat: Add Kafka consumer for orders" - "fix: Correct JSON parsing logic" - "refactor: Optimize database queries"
Security
Authentication
# Identity Providers nifi.registry.security.identity.provider=ldap-identity-provider # LDAP Configuration nifi.registry.security.ldap.manager.dn=cn=admin,dc=example,dc=com nifi.registry.security.ldap.manager.password=password nifi.registry.security.ldap.url=ldap://ldap-server:389 nifi.registry.security.ldap.user.search.base=ou=users,dc=example,dc=com
Authorization
<!-- authorizers.xml --> <authorizers> <userGroupProvider> <identifier>file-user-group-provider</identifier> <class>org.apache.nifi.registry.security.authorization.file.FileUserGroupProvider</class> <property name="Users File">./conf/users.xml</property> <property name="Initial User Identity 1">CN=admin, OU=NiFi</property> </userGroupProvider> <accessPolicyProvider> <identifier>file-access-policy-provider</identifier> <class>org.apache.nifi.registry.security.authorization.file.FileAccessPolicyProvider</class> <property name="User Group Provider">file-user-group-provider</property> <property name="Authorizations File">./conf/authorizations.xml</property> <property name="Initial Admin Identity">CN=admin, OU=NiFi</property> </accessPolicyProvider> </authorizers>
API Usage
REST API Examples
# List buckets curl http://localhost:18080/nifi-registry-api/buckets # Create bucket curl -X POST http://localhost:18080/nifi-registry-api/buckets \ -H "Content-Type: application/json" \ -d '{"name":"MyBucket","description":"Test bucket"}' # List flows in bucket curl http://localhost:18080/nifi-registry-api/buckets/{bucketId}/flows # Get flow versions curl http://localhost:18080/nifi-registry-api/buckets/{bucketId}/flows/{flowId}/versions # Export flow version curl http://localhost:18080/nifi-registry-api/buckets/{bucketId}/flows/{flowId}/versions/{version}/export \ -o flow-export.json
Gitea Integration
When using Gitea as a Git backend for NiFi Registry:
Setup Steps
-
Create Gitea Repository
# In Gitea UI Repository: nifi-flows Visibility: Private Initialize: Yes (with README) -
Generate Access Token
# Gitea Settings → Applications → Generate Token Permissions: repo (all) -
Configure Registry providers.xml
<flowPersistenceProvider> <class>org.apache.nifi.registry.provider.flow.git.GitFlowPersistenceProvider</class> <property name="Flow Storage Directory">./flow_storage</property> <property name="Remote To Push">origin</property> <property name="Remote Access User">gitea-user</property> <property name="Remote Access Password">gitea-access-token</property> </flowPersistenceProvider> -
Initialize Git Repository
cd flow_storage git init git remote add origin http://gitea:3000/user/nifi-flows.git git config user.name "NiFi Registry" git config user.email "registry@nifi.local"
Monitoring & Troubleshooting
Logs
# Main logs logs/nifi-registry-app.log # Application log logs/nifi-registry-user.log # User actions logs/nifi-registry-bootstrap.log # Bootstrap # Enable DEBUG conf/logback.xml → Set level to DEBUG
Common Issues
| Issue | Solution |
|---|---|
| Cannot connect from NiFi | Check network, firewall, registry URL |
| Git push fails | Verify credentials, remote URL, network |
| Flow not visible | Check bucket permissions, user authorization |
| Version conflict | Pull latest, resolve conflicts, recommit |
Migration & Backup
Export All Flows
# Using NiFi Registry CLI (part of NiFi Toolkit) registry list-buckets registry export-all-flows -b bucket-id -o /backup/flows/
Import Flows
registry import-flow-version -f /backup/flows/flow.json -b target-bucket-id
Backup Strategy
# 1. File System Backend tar -czf registry-backup-$(date +%Y%m%d).tar.gz flow_storage/ database/ # 2. Git Backend cd flow_storage && git push --all origin # 3. Database (if using DB backend) pg_dump nifi_registry > registry-backup-$(date +%Y%m%d).sql