Partilhar via


Gatilho de Ligações de Entrada Dapr para o Azure Functions

O Azure Functions pode ser acionado em uma associação de entrada de Dapr usando os seguintes eventos de Dapr.

Para obter informações sobre detalhes de instalação e configuração da extensão Dapr, consulte a visão geral da extensão Dapr.

Example

Uma função C# pode ser criada usando um dos seguintes modos C#:

Execution model Description
Modelo de trabalhador isolado Seu código de função é executado em um processo de trabalho .NET separado. Utilize com versões suportadas do .NET e .NET Framework. Para saber mais, consulte Guia para executar o C# Azure Functions no modelo de trabalhador isolado.
In-process model O código da sua função é executado no mesmo processo que o host de funções. Suporta apenas versões LTS (Long Term Support) do .NET. Para saber mais, consulte Desenvolver funções de biblioteca de classes C# usando o Azure Functions.
[FunctionName("ConsumeMessageFromKafka")]
public static void Run(
    // Note: the value of BindingName must match the binding name in components/kafka-bindings.yaml
    [DaprBindingTrigger(BindingName = "%KafkaBindingName%")] JObject triggerData,
    ILogger log)
{
    log.LogInformation("Hello from Kafka!");
    log.LogInformation($"Trigger data: {triggerData}");
}

Aqui está o código Java para o gatilho Dapr Input Binding:

@FunctionName("ConsumeMessageFromKafka")
public String run(
        @DaprBindingTrigger(
            bindingName = "%KafkaBindingName%")
)

Use o app objeto para registrar o daprBindingTrigger:

const { app, trigger } = require('@azure/functions');

app.generic('ConsumeMessageFromKafka', {
    trigger: trigger.generic({
        type: 'daprBindingTrigger',
        bindingName: "%KafkaBindingName%",
        name: "triggerData"
    }),
    handler: async (request, context) => {
        context.log("Node function processed a ConsumeMessageFromKafka request from the Dapr Runtime.");
        context.log(context.triggerMetadata.triggerData)
    }
});

The following example shows Dapr triggers in a function.json file and PowerShell code that uses those bindings.

Here's the function.json file for daprBindingTrigger:

{
  "bindings": [
    {
      "type": "daprBindingTrigger",
      "bindingName": "%KafkaBindingName%",
      "name": "triggerData",
      "direction": "in"
    }
  ]
}

For more information about function.json file properties, see the Configuration section.

In code:

using namespace System
using namespace Microsoft.Azure.WebJobs
using namespace Microsoft.Extensions.Logging
using namespace Microsoft.Azure.WebJobs.Extensions.Dapr
using namespace Newtonsoft.Json.Linq

param (
    $triggerData
)

Write-Host "PowerShell function processed a ConsumeMessageFromKafka request from the Dapr Runtime."

$jsonString = $triggerData | ConvertTo-Json

Write-Host "Trigger data: $jsonString"

O exemplo a seguir mostra um gatilho Dapr Input Binding, que usa o modelo de programação Python v2. Para usar o código do daprBinding aplicativo na função Python:

import logging
import json
import azure.functions as func

app = func.FunctionApp()

@app.function_name(name="ConsumeMessageFromKafka")
@app.dapr_binding_trigger(arg_name="triggerData", binding_name="%KafkaBindingName%")
def main(triggerData: str) -> None:
    logging.info('Python function processed a ConsumeMessageFromKafka request from the Dapr Runtime.')
    logging.info('Trigger data: ' + triggerData)

Attributes

In the in-process model, use the DaprBindingTrigger to trigger a Dapr input binding, which supports the following properties.

Parameter Description
BindingName O nome do gatilho Dapr. Se não for especificado, o nome da função será usado como o nome do gatilho.

Annotations

A DaprBindingTrigger anotação permite que você crie uma função que é acionada pelo componente de vinculação que você criou.

Element Description
bindingName O nome da ligação Dapr.

Configuration

A tabela a seguir explica as propriedades de configuração de vinculação definidas no código.

Property Description
bindingName O nome da ligação.

A tabela a seguir explica as propriedades de configuração de vinculação definidas no arquivo function.json.

function.json property Description
bindingName O nome da ligação.

A tabela a seguir explica as propriedades de configuração de vinculação definidas @dapp.dapr_binding_trigger no código Python.

Property Description
binding_name O nome da ligação.

See the Example section for complete examples.

Usage

Para usar o gatilho de vinculação de entrada de Dapr, comece configurando um componente de vinculação de entrada de Dapr. Você pode saber mais sobre qual componente usar e como configurá-lo na documentação oficial do Dapr.

Para usar o daprBindingTrigger em Python v2, configure seu projeto com as dependências corretas.

  1. Crie e ative um ambiente virtual.

  2. No ficheiro requirements.text , adicione a seguinte linha:

    azure-functions==1.18.0b3
    
  3. No terminal, instale a biblioteca Python.

    pip install -r .\requirements.txt
    
  4. Modifique seu local.setting.json arquivo com a seguinte configuração:

    "PYTHON_ISOLATE_WORKER_DEPENDENCIES":1
    

Next steps

Saiba mais sobre a invocação do serviço Dapr.