Övning – Analysera begränsningarna för en avsökningsbaserad webbapp

Slutförd

Innan du ändrar prototypen måste du köra den för att verifiera antagandena. Prototypen finns i en källkodslagringsplats på GitHub.

Skapa Azure-resurser

  1. I en separat webbläsarflik eller ett fönster förgrenar du exempellagringsplatsen på GitHub med följande länk: mslearn-advocates.azure-functions-and-signalr. På så sätt kan du skicka ändringarna till din egen version av källkoden. Det här är ett obligatoriskt steg för att distribuera källkoden till Azure senare i modulen.

  2. Klona lagringsplatsen i terminalen. Ersätt med ditt konto i följande kommando MicrosoftDocs :

    git clone https://github.com/MicrosoftDocs/mslearn-advocates.azure-functions-and-signalr stock-prototype
    
  3. Installera beroendena i mappen setup-resources .

    cd stock-prototype/setup-resources && npm install
    

    Om du får varningar om EBADENGINEkan du ignorera dem.

  4. Logga in på Azure med Azure CLI.

    az login
    
  5. Visa dina prenumerationer och ange din standardprenumeration för Azure.

    Visa prenumerationerna.

    az account list --output json | jq -r '.[] | .name' | sort
    

    Om du vill ange standardprenumerationen ersätter du YOUR-SUBSCRIPTION-ID med ett prenumerations-ID från föregående Azure CLI-utdata.

    az account set --subscription <YOUR-SUBSCRIPTION-ID>
    

    Den här standardprenumerationen används för att skapa Azure-resurserna.

  6. Skapa Azure-resurserna och ladda upp exempeldata till databasen. Processen kan ta några minuter att slutföra.

    bash create-start-resources.sh "<YOUR-SUBSCRIPTION-NAME>"
    

    Se till att du omsluter namnet med dubbla citattecken. Om skriptfelen med ett fel om platsen saknar tillgängliga resurser redigerar du skriptet för att ändra platsen: LOCATION=<NEW LOCATION>.

  7. Kopiera nödvändig information, du behöver dessa för att köra prototypen.

    Resurstyp Miljövariabel
    Azure Cosmos DB Kallas COSMOSDB_CONNECTION_STRING
    Azure Storage Kallas STORAGE_CONNECTION_STRING
    Resursgrupp Kallas RESOURCE_GROUP_NAME.
  8. Använd ett Node.js skript för att ladda upp exempeldata till databasen med följande kommando.

    npm start
    
  9. I terminalen navigerar du till rotmappen.

    cd ..
    

Installera beroenden och kör prototypen

  1. Installera beroenden.

    cd start/client && npm install && cd ../..
    cd start/server && npm install && cd ../..
    
  2. Om du uppmanas att välja en Azure Functions-app för arbetsytan väljer du start/server. Det här är funktionsappen som du använder för att köra koden på serversidan.

  3. Om du får ett meddelande om att installera de senaste Azure Functions Core-verktygen väljer du Installera.

Hämta klient- och server-URL:er

När de körs lokalt måste klient- och serverprogrammen veta var de ska hitta varandra. URL:erna är:

  • Klient: http://localhost:3000
  • Server: http://localhost:7071

Uppdatera lokala inställningar för Azure Functions-appen

Lägg till anslutningssträng i prototypens Azure Functions-app.

  1. Skapa filen ./start/server/local.settings.json och klistra in följande. Den här filen har konfigurationsinställningarna för det lokala funktionsprojektet.

    {
      "IsEncrypted": false,
      "Values": {
        "AzureWebJobsStorage": "<STORAGE_CONNECTION_STRING>",
        "FUNCTIONS_WORKER_RUNTIME": "node",
        "AzureWebJobsFeatureFlags": "EnableWorkerIndexing",
        "COSMOSDB_CONNECTION_STRING": "<COSMOSDB_CONNECTION_STRING>"
      },
      "Host" : {
        "LocalHttpPort": 7071,
        "CORS": "http://localhost:3000",
        "CORSCredentials": true
      }
    }
    
  2. Uppdatera följande variabler med värden som du kopierade från ovan.

    Property Värde
    AzureWebJobsStorage Ersätt med Storage-anslutningssträng.
    COSMOSDB_CONNECTION_STRING Ersätt med Cosmos DB-anslutningssträng.

    Nu kan Functions-appen ta emot begäranden från klienten och sedan ansluta till databasen och hantera timerutlösaren korrekt.

Lägga till lokala inställningar för klientappen

Lägg till server-URL:en i prototypens klientprogram.

Öppna ./start/client och skapa en .env fil med följande innehåll.

BACKEND_URL=http://localhost:7071

Kör serverprogrammet

  1. Starta Azure Functions-programmet i terminalen.

    cd start/server && npm start
    
  2. Vänta tills terminalen visar API-slutpunkterna.

    Functions:
    
            getStocks: [GET] http://localhost:7071/api/getStocks
    
            setPrice: timerTrigger
    

Kör klientprogrammet

  1. Starta klientprogrammet i en ny terminal.

    cd start/client && npm start
    
    
  2. När meddelandet visar att programmet körs väljer du Öppna i webbläsare för att använda prototypen.

    Skärmbild av Visual Studio Code-meddelande för att öppna webbläsaren.

  3. Ordna webbläsarfönstren så att du kan se terminalen och prototypen av aktiekurserna samtidigt.

  4. Öppna webbläsarens utvecklarverktyg i prototypwebbläsarens fönster. Observera att webbläsaren skickar en begäran till API:et var femte sekund för alla data, även om data inte har ändrats.

  5. I webbläsarfönstret tittar du på utdata för Azure Functions-appen. En enda aktiekurs ändras varje minut. När priset i API:et ändras inkluderar nästa klienthämtning av alla data den ändringen.

    Skärmbild av Visual Studio Code-terminalen som visar konsolutdata från aktiekursändringen.

  6. I både startklient- och startserverterminalerna stoppar du programmen med Ctrl + C eller avslutar terminalen genom att välja papperskorgsikonen.

I den här lektionen körde du prototypen. Även om klienten körs är den inte effektiv. Även om varje enskild klient kanske inte märker detta med ett så litet antal aktier, kommer det att ändras när antalet aktier växer och antalet klienter hämtar från servern. Prototypen kan förbättras. Nu ska vi lära oss mer i nästa lektion.