如何使用Rest-API更改Nifi变量注册表

spo*_*oof 0 apache-nifi

我知道可以使用rest-api检索变量注册表中的值,但是有没有办法设置变量值?当我更改变量时,我看到发送了以下POST:

http://localhost:8080/nifi-api/process-groups/{ID}/variable-registry/update-requests
Run Code Online (Sandbox Code Playgroud)

但是我不太了解VariableRegistryEntity在哪里发挥作用,或者如何处理变量。

更广泛地说,我想做的是在另一个程序的自定义Nifi处理器中操作变量,因此,欢迎您提供任何指导或想法。

Shu*_*Shu 6

所有变量(键,值)都存储在变量注册表中,当我们更新/创建变量时,我们将在后端进行更新请求rest api调用。

如果您正在构建自定义的处理器使用the variables,那么你需要create processor使表达式语言,那么你可以通过使用参考变量nifi expression language ${variable_name}将与替换variable_value at run time

请参阅链接,以获取有关NiFi中的变量注册表的更多详细信息。

如果您需要在Nifi中更新/创建任何变量,则可以使用以下rest api调用:

bash$ curl -i -H 'Content-Type: application/json' -X POST -d '{\
    "processGroupRevision": {\
        "clientId": "<ClientId>",\
        "version": 0\
    },\
    "variableRegistry": {\
        "processGroupId": "<process-group-id>",\
        "variables": [{\
            "variable": {\
                "name": "<variable-name>",\
                "value": "<variable-value>"\
            }\
        }]\
    }\
}' <URL>/nifi-api/process-groups/<process-group-id>/variable-registry/update-requests
Run Code Online (Sandbox Code Playgroud)

该curl调用将更新值

  • 如果已经定义变量并且更改了值,则停止并启动所有受影响的控制器服务和处理器在此处输入图片说明
  • 如果尚未定义变量,则使用定义的值创建新变量。

如何获得ClientID?

您可以进行以下Get Rest api调用:

curl -X GET <URL>/nifi-api/process-groups/<process-group-id>/variable-registry
Run Code Online (Sandbox Code Playgroud)

从响应中,您可以获取clientID详细信息。

  • 还想提到NiFi CLI具有set-var命令,可以帮助自动执行此处提到的REST API调用 (3认同)