ApacheNifi中的ListSFTPProcessor无法取出文件,请提供一个解决方案(最好有代码示例)。
创始人
2024-09-06 07:00:57
0
  1. 确保您已正确设置了SFTP连接并将其添加到List SFTP Processor中,并且您具有正确的文件系统权限。

  2. 检查您的List SFTP Processor是否有正确的文件过滤器设置。

  3. 尝试升级您的Apache Nifi版本,因为某些旧版本可能存在该问题。

  4. 检查您的操作系统、Java和Apache Nifi的日志,确定是否存在任何错误或异常。

  5. 尝试使用其他SFTP工具,例如WinSCP或FileZilla,检查能否从该SFTP连接下载文件。

下面是Python代码示例,使用Apache Nifi API来列出指定目录中的SFTP文件。

import nipyapi
from nipyapi import canvas, nifi
from pprint import pprint

# 获取Apache Nifi API参数
nipyapi.config.nifi_config.host = 'http://localhost:8080/nifi-api'
nipyapi.config.registry_config.verify_ssl = False

# 获取认证令牌
credentials = nifi.UserCredentialsDto()
credentials.username = 'admin'
credentials.password = 'admin'

# 您的SFTP连接配置
sftp_connection = nifi.SFTPListingRequestDTO()
sftp_connection.host = '192.168.0.100'
sftp_connection.port = 22
sftp_connection.username = 'user'
sftp_connection.password = 'password'
sftp_connection.remote_path = '/example/path'

# 用ListSFTPProcessor列出SFTP目录中的文件
processor_fqn = 'org.apache.nifi.processors.sftp.ListSFTP'
processor_name = 'ListSFTP'
processor_loc = nipyapi.canvas.get_process_group('My Process Group').id
processor = canvas.create_processor(
    parent_pg=processor_loc,
    processor=nifi.ProcessorConfigDTO(
        type=processor_fqn,
        name=processor_name,
        position=nifi.PositionDTO(x=400.0, y=400.0)
    )
)
canvas.set_processor_relationships(
    processor,
    {
        'success': ((processor, 'success'),),
        'failure': ((processor, 'failure'),)
    }
)
canvas.update_processor(
    processor,
    nifi.ProcessorConfigDTO(
        id=processor.id,
        properties={
            'Remote Host': sftp_connection.host,
            'Remote Port': sftp_connection.port,
            'Username': sftp_connection.username,
            'Password': sftp_connection.password,
            'Remote Path': sftp_connection.remote_path,
            'File Filter': '',
            'Query Interval': '5 sec',
            'Minimum File Age': '0 sec',
            'Maximum File Age': '0 sec',
            'Ignore Dotted Files': 'true',
            'Recursive Search': 'false',
            'Listing Strategy': 'using chronological order',
            'List File Attributes': 'false',
            'Batch Size': '100'
        },
        state='STOPPED'
    )
)
pprint(canvas.list_all_processors(process_group_id=processor_loc))

# 运行processor
canvas.schedule_processor(processor)

# 获取文件
proc_state = None
while proc_state not in {'RUNNING', 'STOPPED'}:
    processor_data = nipyapi.canvas.get_processor(processor.id, 'id')
    proc_state = processor_data.status.aggregate_snapshot.status

# 获取文件列表
file_listing = nifi.get_all_flowfiles(
    nifi.list_all_processors(process_group_id=processor_loc)
    ['processors'][0]['

相关内容

热门资讯

银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
AsusVivobook无法开... 首先,我们可以尝试重置BIOS(Basic Input/Output System)来解决这个问题。...
ASM贪吃蛇游戏-解决错误的问... 要解决ASM贪吃蛇游戏中的错误问题,你可以按照以下步骤进行:首先,确定错误的具体表现和问题所在。在贪...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...