Skapa durable functions med hjälp av Azure Portal
Durable Functions-tillägget för Azure Functions finns i NuGet-paketet Microsoft.Azure.WebJobs.Extensions.DurableTask. Det här tillägget måste vara installerat i funktionsappen. Den här artikeln visar hur du installerar det här paketet så att du kan utveckla hållbara funktioner i Azure Portal.
Kommentar
- Om du utvecklar hållbara funktioner i C# bör du i stället överväga Visual Studio 2019-utveckling.
- Om du utvecklar varaktiga funktioner i JavaScript bör du i stället överväga Visual Studio Code-utveckling.
Skapa en funktionsapp
Du måste ha en funktionsapp som värd för körningen av alla funktioner. Med en funktionsapp kan du gruppera dina funktioner som en logisk enhet för enklare hantering, distribution, skalning och delning av resurser. Du kan skapa en .NET- eller JavaScript-app.
I menyn i Azure-portalen eller på sidan Start väljer du Skapa en resurs.
På sidan Nytt väljer du Beräkningsfunktionsapp>.
Under Välj ett värdalternativ väljer du Förbrukning>Välj för att skapa din app i standardförbrukningsplanen. I det här serverlösa värdalternativet betalar du bara för den tid som dina funktioner körs. Premium-planen erbjuder även dynamisk skalning. När du använder en App Service-plan måste du hantera funktionsappens skalning.
På sidan Grundläggande använder du inställningarna för funktionsappen enligt beskrivningen i följande tabell:
Inställning Föreslaget värde beskrivning Abonnemang Din prenumeration Prenumerationen där du skapar din nya funktionsapp. Resursgrupp myResourceGroup Namn på den nya resursgrupp där du skapar funktionsappen. Du bör skapa en ny resursgrupp eftersom det finns kända begränsningar när du skapar nya funktionsappar i en befintlig resursgrupp. Funktionsappens namn Globalt unikt namn Namn som identifierar din nya funktionsapp. Giltiga tecken är a-z
(skiftlägesokänsligt),0-9
och-
.Körningsstack Önskat språk Välj en körning som stöder det funktionsprogrammeringsspråk som du föredrar. Redigering i portalen är endast tillgängligt för JavaScript-, PowerShell-, Python-, TypeScript- och C#-skript.
Om du vill skapa en C#-skriptapp som stöder redigering i portalen måste du välja en körningsversion som stöder den processbaserade modellen.
C#-klassbibliotek och Java-funktioner måste utvecklas lokalt.Version: Versionsnummer Välj den version av din installerade körning. Region Önskad region Välj en region som är nära dig eller nära andra tjänster som dina funktioner kan komma åt. Operativsystem Windows Ett operativsystem är förvalt baserat på val av körningsstack, men du kan ändra inställningen om det behövs. Redigering i portalen stöds endast i Windows. Acceptera standardalternativen på de återstående flikarna, inklusive standardbeteendet för att skapa ett nytt lagringskonto på fliken Lagring och en ny Application Insight-instans på fliken Övervakning . Du kan också välja att använda ett befintligt lagringskonto eller En Application Insights-instans.
Välj Granska + skapa för att granska appkonfigurationen du valde och välj sedan Skapa för att etablera och distribuera funktionsappen.
Välj ikonen Meddelanden i det övre högra hörnet i portalen och håll utkik efter meddelandet Distributionen lyckades.
Välj Gå till resurs för att se den nya funktionsappen. Du kan också välja Fäst på instrumentpanelen. Med fästning blir det enklare att återgå till den här funktionsappresursen från instrumentpanelen.
Som standard använder funktionsappen som skapats version 2.x av Azure Functions-körningen. Durable Functions-tillägget fungerar på båda versionerna 1.x och 2.x av Azure Functions-körningen i C# och version 2.x i JavaScript. Mallar är dock endast tillgängliga när du riktar in dig på version 2.x av körningen oavsett vilket språk du väljer.
Installera npm-paketet durable-functions (endast JavaScript)
Om du skapar JavaScript Durable Functions måste du installera durable-functions
npm-paketet:
På funktionsappens sida väljer du Avancerade verktyg under Utvecklingsverktyg i den vänstra rutan.
På sidan Avancerade verktyg väljer du Gå.
I Kudu-konsolen väljer du Felsökningskonsol och sedan CMD.
Funktionsappens filkatalogstruktur bör visas. Gå till mappen
site/wwwroot
. Därifrån kan du ladda upp enpackage.json
fil genom att dra och släppa den i filkatalogfönstret. Ett exempelpackage.json
finns nedan:{ "dependencies": { "durable-functions": "^1.3.1" } }
När du
package.json
har laddat upp körnpm install
du kommandot från Kudu-fjärrkörningskonsolen.
Skapa en orchestrator-funktion
I funktionsappen väljer du Funktioner i den vänstra rutan och väljer sedan Lägg till på den översta menyn.
I sökfältet på sidan Ny funktion anger du
durable
och väljer sedan mallen Durable Functions HTTP starter .För namnet Ny funktion anger du
HttpStart
och väljer sedan Skapa funktion.Funktionen som skapas används för att starta orkestreringen.
Skapa en annan funktion i funktionsappen, den här gången med hjälp av orchestratormallen Durable Functions. Ge den nya orkestreringsfunktionen
HelloSequence
namnet .Skapa en tredje funktion med namnet
Hello
med hjälp av aktivitetsmallen Durable Functions.
Testa den hållbara funktionsorkestreringen
Gå tillbaka till Funktionen HttpStart, välj Hämta funktions-URL och välj ikonen Kopiera till Urklipp för att kopiera URL:en. Du använder den här URL:en för att starta funktionen HelloSequence .
Använd ett säkert HTTP-testverktyg för att skicka en HTTP POST-begäran till URL-slutpunkten. Det här exemplet är ett cURL-kommando som skickar en POST-begäran till den varaktiga funktionen:
curl -X POST https://{your-function-app-name}.azurewebsites.net/api/orchestrators/{functionName} --header "Content-Length: 0"
I det här exemplet
{your-function-app-name}
är den domän som är namnet på din funktionsapp och{functionName}
är funktionen HelloSequence orchestrator. Svarsmeddelandet innehåller en uppsättning URI-slutpunkter som du kan använda för att övervaka och hantera körningen, som ser ut som följande exempel:{ "id":"10585834a930427195479de25e0b952d", "statusQueryGetUri":"https://...", "sendEventPostUri":"https://...", "terminatePostUri":"https://...", "rewindPostUri":"https://..." }
Se till att välja ett HTTP-testverktyg som skyddar dina data. Mer information finns i HTTP-testverktyg.
Anropa slutpunkts-URI
statusQueryGetUri
:n och du ser den aktuella statusen för den varaktiga funktionen, som kan se ut som i det här exemplet:{ "runtimeStatus": "Running", "input": null, "output": null, "createdTime": "2017-12-01T05:37:33Z", "lastUpdatedTime": "2017-12-01T05:37:36Z" }
Fortsätt att anropa
statusQueryGetUri
slutpunkten tills statusen ändras till Slutförd och du ser ett svar som i följande exempel:{ "runtimeStatus": "Completed", "input": null, "output": [ "Hello Tokyo!", "Hello Seattle!", "Hello London!" ], "createdTime": "2017-12-01T05:38:22Z", "lastUpdatedTime": "2017-12-01T05:38:28Z" }
Din första varaktiga funktion är nu igång i Azure.