Övning – skapa ett nytt API i API Management från en funktionsapp
Om du vill presentera Azure Functions för användare som delar av ett enda API kan du lägga till dem i Azure API Management.
I ditt onlinebutiksföretag skapade utvecklarna flera Azure Functions som mikrotjänster. Varje funktion implementerar en liten del av butikens funktioner. Du vill montera dessa funktioner i ett enda API.
I den här övningen skapar du en ny API Management-instans och lägger sedan till en produktinformationsfunktion i den.
Skapa funktioner
I följande steg lägger du till en Azure-funktionsapp i Azure API Management. Senare lägger du till en andra funktionsapp i samma API Management-instans för att skapa ett enda serverlöst API från flera funktioner. Vi börjar med att använda ett skript för att skapa funktionerna:
Om du vill klona funktionsprojektet kör du följande kommando i Azure Cloud Shell till höger.
git clone https://github.com/MicrosoftDocs/mslearn-apim-and-functions.git ~/OnlineStoreFuncs
Kör följande kommandon i Cloud Shell för att konfigurera nödvändiga Azure-resurser som vi behöver för den här övningen.
cd ~/OnlineStoreFuncs bash setup.sh
Skriptet
setup.sh
skapar de två funktionsapparna i sandbox-resursgruppen som aktiveras för den här modulen. När följande bild illustreras är varje app värd för en enda funktion –OrderDetails
ochProductDetails
. Skriptet konfigurerar också ett lagringskonto för funktionerna. Funktionerna har båda URL:erna i domänen azurewebsites.net-domänen. Funktionsnamnen innehåller slumpmässiga siffror för unikhet. Det tar några minuter att slutföra skriptet.
Testa funktionen produktinformation
Nu ska vi testa funktionen ProductDetails för att se hur den fungerar innan vi lägger till den i API Management.
Logga in på Azure-portalen med samma konto som du använde till att aktivera sandbox-miljön.
På menyn i Azure-portalen eller från startsidan väljer du Alla resurser. Fönstret Alla resurser visas.
Välj den funktionsapp vars namn börjar med ProductFunction. Fönstret Funktionsapp visas med fliken Översikt markerad.
I listan över funktioner för din funktionsapp väljer du ProductDetails. Fönstret ProductDetails-funktion visas.
På menyn Produktinformation går du till Utvecklare och väljer Kod + Test. Fönstret Kod + test för funktionen ProductDetails visas och visar innehållet i
function.json
filen.I kommandofältet väljer du Test/Kör. Fönstret Indata/utdata visas för att testa DIN HTTP-begäran.
På fliken Indata går du till listrutan HTTP-metodfält och väljer GET.
Under Fråga väljer du Lägg till parameter
I fältet Namn anger du ID och i fältet Värde anger du 3 och väljer sedan Kör.
En loggruta visas för att ansluta begäran. Fliken Utdata visar HTTP-svarskoden (200 OK) och innehållet för objekt 3 i databasen.
Du kan också testa funktionen genom att ange ID-värdena 1 och 2.
Välj Stäng för att stänga flikarna Indatautdata för Kod + Test.
I kommandofältet i fönstret ProductDetails Code + Test väljer du Hämta funktions-URL. Observera att URL-underdomänen är namnet på din funktionsapp följt av azurewebsites.net domän.
Kommentar
Du kan använda den här URL:en för att testa funktionen i webbläsaren. URL:en kräver indata. lägg till frågesträngen &id=1
för att begära information om det första objektet i produktsamlingen.
Exponera funktionsappen som ett API med Hjälp av Azure API Management
När funktionsappen har distribuerats och testats ska vi exportera den som ett API med Hjälp av Azure API Management så att den kan anropas från andra appar och tjänster.
I resursmenyn väljer du Alla resurser. Fönstret Alla resurser visas.
Sortera listan över resurser efter typ. Observera att du har en OrderFunction-app och en ProductFunction-app.
Välj funktionsappen ProductFunction .
I menyn Funktionsapp bläddrar du till API-kategorin och väljer sedan API Management. Fönstret API Management för funktionsappen ProductFunction visas.
Under fältet API Management väljer du Skapa ny. Fönstret Installera API Management-gateway visas.
Ange följande värden för varje inställning.
Inställning Värde Prenumeration Concierge-prenumeration Resursgrupp [namn på sandbox-miljöns resursgrupp] Region Välj en plats som stöder förbrukningsplanen: (USA) USA, västra, USA, norra centrala, Europa, västra, Europa, norra, Sydostasien, Australien, östra Resursnamn OnlineStore Organisationsnamn OnlineStore E-postadress för administratör Ange en e-postadress. Prisnivå Förbrukning (99,95 % serviceavtal) Välj Nästa: Övervaka och avmarkera alternativet Application Insights .
Välj Granska + skapa. När verifieringen är klar väljer du Skapa för att skapa en länkad API Management-instans. Tillåt flera minuter för att exporten ska slutföras.
När API Management-instansen har distribuerats väljer du Länk-API.
Fönstret Importera Azure Functions API Management-tjänsten visas med funktionen ProductDetails markerad.
Välj Välj för att fortsätta. Dialogrutan Skapa från funktionsapp visas.
Ändra värdet för API URL-suffixet till produkter och välj sedan Skapa. Azure skapar API:et för funktionen ProductDetails . Fliken Design för API Management för funktionsappen visas.
Den här övningen visar att du kan definiera ditt API, allt från Azure Function App Service.
Testa slutpunkten för OnlineStore-produkter
Nu har du ett ProductDetails
API i API Management-instansen som du skapade. Nu ska vi testa API:et med API Management-verktygen i Azure.
I fönstret API Management i funktionsappen väljer du fliken Test . Tillgängliga åtgärder för ditt API visas i den vänstra kolumnen.
Välj GET ProductDetails. Fönstret ProductDetails-konsolen visas.
Under frågeparametrar väljer du Lägg till parameter.
I fältet NAMN anger du ID och i fältet VÄRDE anger du 1 och väljer sedan Skicka för att generera en GET-begäran.
Avsnittet HTTP-svar i konsolen har två flikar, Meddelande och Spårning. Fliken Meddelande fylls i med HTTP-svaret. Produktinformationen visas i JSON-format i slutet av svaret. Rulla upp till avsnittet HTTP-begäran och lägg märke till formatet för begäran. Begäran skickades till ett mål i domänen azure-api.net . Den här platsen skiljer sig från den azurewebsites.net domän där funktionsappen finns. Du kan testa det här API:et med andra frågeparametrar, till exempel id=2 eller id=3.