Skapa en PHP-webbapp i Azure App Service

Azure App Service är en mycket skalbar webbvärdtjänst med självkorrigering. Den här snabbstartsguiden visar hur du distribuerar en PHP-app till Azure App Service i Windows.

Du skapar webbappen med Azure CLI i Cloud Shell och använder Git för att distribuera PHP-exempelkoden till webbappen.

Exempelapp som körs i Azure

Du kan följa stegen här på en Mac-, Windows- eller Linux-dator. Det tar cirka fem minuter att slutföra självstudiekursen när de nödvändiga komponenterna har installerats.

Om du inte har en Azure-prenumeration kan du skapa ett kostnadsfritt Azure-konto innan du börjar.

Förutsättningar

För att slutföra den här snabbstarten behöver du:

Ladda ned exemplet lokalt

  1. Kör följande kommandon i ett terminalfönster. Exempelprogrammet klonas till den lokala datorn och navigerar till katalogen som innehåller exempelkoden.

    git clone https://github.com/Azure-Samples/php-docs-hello-world
    cd php-docs-hello-world
    
  2. Kontrollera att standardgrenen är main.

    git branch -m main
    

    Tips

    Ändringen av grennamnet krävs inte av App Service. Men eftersom många lagringsplatser ändrar sin standardgren till mainvisar den här snabbstarten också hur du distribuerar en lagringsplats från main.

Köra appen lokalt

  1. Kör programmet lokalt så att du ser hur det ska se ut när du distribuerar det till Azure. Öppna ett terminalfönster och använd kommandot php för att starta den inbyggda PHP-webbservern.

    php -S localhost:8080
    
  2. Öppna en webbläsare och navigera till exempelappen på http://localhost:8080.

    Du ser meddelandet Hello World! från exempelappen som visas på sidan.

    Exempelapp som körs lokalt

  3. Tryck på Ctrl+C i terminalfönstret för att avsluta webbservern.

Azure Cloud Shell

Azure är värd för Azure Cloud Shell, en interaktiv gränssnittsmiljö som du kan använda via webbläsaren. Du kan använda antingen Bash eller PowerShell med Cloud Shell för att arbeta med Azure-tjänster. Du kan använda Cloud Shell förinstallerade kommandon för att köra koden i den här artikeln utan att behöva installera något i din lokala miljö.

Så här startar du Azure Cloud Shell:

Alternativ Exempel/länk
Välj Prova i det övre högra hörnet i ett kod- eller kommandoblock. Om du väljer Prova kopieras inte koden eller kommandot automatiskt för att Cloud Shell. Skärmbild som visar ett exempel på Prova för Azure Cloud Shell.
Gå till https://shell.azure.com eller Välj knappen Starta Cloud Shell för att öppna Cloud Shell i webbläsaren. Skärmbild som visar hur du startar Cloud Shell i ett nytt fönster.
Välj knappen Cloud Shell på menyn längst upp till höger i Azure-portalen. Skärmbild som visar knappen Cloud Shell i Azure Portal

Så här använder du Azure Cloud Shell:

  1. Starta Cloud Shell.

  2. Välj knappen Kopiera i ett kodblock (eller kommandoblock) för att kopiera koden eller kommandot.

  3. Klistra in koden eller kommandot i den Cloud Shell sessionen genom att välja Ctrl+Skift+V i Windows och Linux, eller genom att välja Cmd+Skift+V på macOS.

  4. Välj Retur för att köra koden eller kommandot.

Konfigurera en distributionsanvändare

FTP och lokal Git kan distribueras till en Azure-webbapp med hjälp av en distributionsanvändare. När du har konfigurerat distributionsanvändaren kan du använda den för alla dina Azure-distributioner. Ditt användarnamn och lösenord för distribution på kontonivå skiljer sig från autentiseringsuppgifterna för din Azure-prenumeration.

Om du vill konfigurera distributionsanvändaren kör du kommandot az webapp deployment user set i Azure Cloud Shell. Ersätt <användarnamn> och <lösenord> med ett användarnamn och lösenord för distributionsanvändaren.

  • Användarnamnet måste vara unikt i Azure, och för lokala Git-pushar får det inte innehålla @-symbolen.
  • Lösenordet måste vara minst åtta tecken långt, med två av följande tre element: bokstäver, siffror och symboler.
az webapp deployment user set --user-name <username> --password <password>

JSON-utdata visar lösenordet som null. Om du ser felet 'Conflict'. Details: 409 ska du byta användarnamn. Om du ser felet 'Bad Request'. Details: 400 ska du använda ett starkare lösenord.

Registrera ditt användarnamn och lösenord som ska användas för att distribuera dina webbappar.

Skapa en resursgrupp

En resursgrupp är en logisk container där Azure-resurser, till exempel webbappar, databaser och lagringskonton, distribueras och hanteras. Du kan exempelvis välja att ta bort hela resursgruppen i ett enkelt steg längre fram.

Skapa i Cloud Shell en resursgrupp med kommandot az group create. I följande exempel skapas en resursgrupp med namnet myResourceGroup på platsen Europa, västra. Om du vill se alla platser som stöds för App Service på Kostnadsfri nivå, kör du kommandot az appservice list-locations --sku FREE.

az group create --name myResourceGroup --location "West Europe"

Du skapar vanligtvis din resursgrupp och resurserna i en region nära dig.

När kommandot har slutförts visar JSON-utdata resursgruppens egenskaper.

Skapa en Azure App Service-plan

Skapa i Cloud Shell en App Service-plan med kommandot az appservice plan create.

I följande exempel skapas en App Service-plan med namnet myAppServicePlan på prisnivån Kostnadsfri:

az appservice plan create --name myAppServicePlan --resource-group myResourceGroup --sku FREE --is-linux

När App Service-planen har skapats visas information av Azure CLI. Informationen ser ut ungefär som i följande exempel:

{ 
  "freeOfferExpirationTime": null,
  "geoRegion": "West Europe",
  "hostingEnvironmentProfile": null,
  "id": "/subscriptions/0000-0000/resourceGroups/myResourceGroup/providers/Microsoft.Web/serverfarms/myAppServicePlan",
  "kind": "linux",
  "location": "West Europe",
  "maximumNumberOfWorkers": 1,
  "name": "myAppServicePlan",
  < JSON data removed for brevity. >
  "targetWorkerSizeId": 0,
  "type": "Microsoft.Web/serverfarms",
  "workerTierName": null
} 

Skapa en webbapp

  1. Skapa i Cloud Shell en webbapp i myAppServicePlan App Service-planen med kommandot az webapp create.

    Ersätt <app-name> med ett globalt unikt appnamn (giltiga tecken är a-z, 0-9 och -) i följande exempel. Körningen har angetts till PHP|7.4. Om du vill se alla körningar som stöds ska du köra az webapp list-runtimes.

    az webapp create --resource-group myResourceGroup --plan myAppServicePlan --name <app-name> --runtime 'PHP|7.4' --deployment-local-git
    

    När webbappen har skapats visar Azure CLI utdata liknande den i följande exempel:

     Local git is configured with url of 'https://<username>@<app-name>.scm.azurewebsites.net/<app-name>.git'
     {
       "availabilityState": "Normal",
       "clientAffinityEnabled": true,
       "clientCertEnabled": false,
       "cloningInfo": null,
       "containerSize": 0,
       "dailyMemoryTimeQuota": 0,
       "defaultHostName": "<app-name>.azurewebsites.net",
       "enabled": true,
       < JSON data removed for brevity. >
     }
     

    Du har skapat en tom ny webbapp med git-distribution aktiverad.

    Anteckning

    URL för fjärransluten Git visas i egenskapen deploymentLocalGitUrl med formatet https://<username>@<app-name>.scm.azurewebsites.net/<app-name>.git. Spara den här URL:en, eftersom du behöver den senare.

  2. Bläddra till webbappen som precis skapades. Ersätt <app-name> med ditt unika appnamn som skapades i föregående steg.

    http://<app-name>.azurewebsites.net
    

    Så här bör din nya webbapp se ut:

    Tom webbappsida

Skicka till Azure från Git

  1. Eftersom du distribuerar -grenen main måste du ange standarddistributionsgrenen för din App Service-app till main (se Ändra distributionsgren). I Cloud Shell anger du appinställningen DEPLOYMENT_BRANCHaz webapp config appsettings set med kommandot .

    az webapp config appsettings set --name <app-name> --resource-group myResourceGroup --settings DEPLOYMENT_BRANCH='main'
    
  2. I det lokala terminalfönstret kan du lägga till en Azure-fjärrdatabas till din lokala Git-databas. Ersätt <deploymentLocalGitUrl-from-create-step> med URL:en för den Fjärranslutna Git som du sparade från Skapa en webbapp.

    git remote add azure <deploymentLocalGitUrl-from-create-step>
    
  3. Skicka till Azure-fjärrdatabasen för att distribuera appen med följande kommando. När Git Credential Manager frågar efter autentiseringsuppgifter ska du ange de autentiseringsuppgifter som du skapade i Konfigurera en distributionsanvändare, inte de autentiseringsuppgifter som du använder för att logga in på Azure Portal.

    git push azure main
    

    Det kan ett par minuter att köra kommandot. Medan det körs visas information liknande den i följande exempel:

  Counting objects: 2, done.
  Delta compression using up to 4 threads.
  Compressing objects: 100% (2/2), done.
  Writing objects: 100% (2/2), 352 bytes | 0 bytes/s, done.
  Total 2 (delta 1), reused 0 (delta 0)
  remote: Updating branch 'main'.
  remote: Updating submodules.
  remote: Preparing deployment for commit id '25f18051e9'.
  remote: Generating deployment script.
  remote: Running deployment command...
  remote: Handling Basic Web Site deployment.
  remote: Kudu sync from: '/home/site/repository' to: '/home/site/wwwroot'
  remote: Copying file: '.gitignore'
  remote: Copying file: 'LICENSE'
  remote: Copying file: 'README.md'
  remote: Copying file: 'index.php'
  remote: Ignoring: .git
  remote: Finished successfully.
  remote: Running post deployment command(s)...
  remote: Deployment successful.
  To https://<app-name>.scm.azurewebsites.net/<app-name>.git
      cc39b1e..25f1805  main -> main
  

Bläddra till appen

Bläddra till den distribuerade appen via webbläsaren.

http://<app-name>.azurewebsites.net

PHP-exempelkoden körs i en Azure App Service-webbapp.

Exempelapp som körs i Azure

Grattis! Du har distribuerat din första PHP-app till App Service.

Uppdatera lokalt och distribuera om koden

  1. Öppna filen index.php i PHP-appen med ett lokalt textredigeringsprogram och gör små ändringar i texten i strängen bredvid echo:

    echo "Hello Azure!";
    
  2. I det lokala terminalfönstret sparar du ändringarna i Git och skickar sedan kodändringarna till Azure.

    git commit -am "updated output"
    git push azure main
    
  3. När distributionen är klar går du tillbaka till webbläsarfönstret som öppnades när du skulle söka efter appen och klickar på knappen för att uppdatera sidan.

    Uppdaterad exempelapp som körs i Azure

Hantera din nya Azure-app

  1. Gå till Azure Portal för att hantera den webbapp som du skapade. Sök efter och välj App Services.

    Sök efter App Services, Azure Portal, skapa PHP-webbapp

  2. Välj namnet på din Azure-app.

    Portalnavigering till Azure-app

    Webbappens översiktssida visas. Här kan du utföra grundläggande hanteringsuppgifter som Bläddra, Stoppa, Starta om och Ta bort.

    App Service-sidan på Azure Portal

    Webbappmenyn innehåller olika alternativ för att konfigurera din app.

Rensa resurser

I de föregående stegen skapade du Azure-resurser i en resursgrupp. Om du inte tror att du behöver dessa resurser i framtiden tar du bort resursgruppen genom att köra följande kommando i Cloud Shell:

az group delete --name myResourceGroup

Det kan några minuter att köra kommandot.

Azure App Service ger en mycket skalbar webbvärdtjänst med självkorrigering. Den här snabbstarten visar hur du distribuerar en PHP-app till Azure App Service i Linux.

Skärmbild av exempelappen som körs i Azure.

Du kan följa stegen här på en Mac-, Windows- eller Linux-dator. Det tar cirka fem minuter att slutföra självstudiekursen när de nödvändiga komponenterna har installerats.

För att slutföra den här snabbstarten behöver du:

1 – Hämta exempellagringsplatsen

Du kan skapa webbappen med hjälp av Azure CLI i Cloud Shell och du använder Git för att distribuera PHP-exempelkod till webbappen.

  1. Kör följande kommandon i ett terminalfönster. Det klonar exempelprogrammet till den lokala datorn och navigerar till katalogen som innehåller exempelkoden.

    git clone https://github.com/Azure-Samples/php-docs-hello-world
    cd php-docs-hello-world
    
  2. Om du vill köra programmet lokalt använder du php kommandot för att starta den inbyggda PHP-webbservern.

    php -S localhost:8080
    
  3. Bläddra till exempelprogrammet i http://localhost:8080 en webbläsare.

    Skärmbild av exempelappen som körs lokalt.

  4. Tryck på Ctrl+C i terminalfönstret för att avsluta webbservern.

2 – Distribuera programkoden till Azure

Azure CLI har ett kommando az webapp up som skapar nödvändiga resurser och distribuerar ditt program i ett enda steg.

Distribuera koden i den lokala mappen i terminalen az webapp up med kommandot :

az webapp up --runtime "PHP:8.0" --os-type=linux
  • az Om kommandot inte känns igen kontrollerar du att Du har Azure CLI installerat.
  • Argumentet --runtime "PHP:8.0" skapar webbappen med PHP version 8.0.
  • Argumentet --os-type=linux skapar webbappen på App Service på Linux.
  • Du kan också ange ett namn med argumentet --name <app-name>. Om du inte anger något genereras ett namn automatiskt.
  • Du kan också inkludera argumentet --location <location-name> där <location_name> det finns en tillgänglig Azure-region. Du kan hämta en lista över tillåtna regioner för ditt Azure-konto genom att az account list-locations köra kommandot .
  • Om du ser felet "Det gick inte att automatiskt identifiera körningsstacken för din app" kontrollerar du att du kör kommandot i kodkatalogen (se Felsöka problem med automatisk identifiering med az webapp up).

Det kan ta några minuter att slutföra kommandot. När den körs visas meddelanden om hur du skapar resursgruppen, App Service-planen och appresursen, konfigurerar loggning och utför ZIP-distribution. Meddelandet "Du kan starta appen på http://< app-name.azurewebsites.net>", som är appens URL i Azure.

The webapp '<app-name>' doesn't exist
Creating Resource group '<group-name>' ...
Resource group creation complete
Creating AppServicePlan '<app-service-plan-name>' ...
Creating webapp '<app-name>' ...
Configuring default logging for the app, if not already enabled
Creating zip with contents of dir /home/msangapu/myPhpApp ...
Getting scm site credentials for zip deployment
Starting zip deployment. This operation can take a while to complete ...
Deployment endpoint responded with status code 202
You can launch the app at http://<app-name>.azurewebsites.net
{
  "URL": "http://<app-name>.azurewebsites.net",
  "appserviceplan": "<app-service-plan-name>",
  "location": "centralus",
  "name": "<app-name>",
  "os": "linux",
  "resourcegroup": "<group-name>",
  "runtime_version": "php|8.0",
  "runtime_version_detected": "0.0",
  "sku": "FREE",
  "src_path": "//home//msangapu//myPhpApp"
}

Anteckning

Kommandot az webapp up utför följande åtgärder:

Bläddra till det distribuerade programmet i webbläsaren på URL:en http://<app-name>.azurewebsites.net.

PHP-exempelkoden körs i en Azure App Service.

Skärmbild av exempelappen som körs i Azure och som visar

Grattis! Du har distribuerat din första PHP-app för att App Service med hjälp av Azure Portal.

3 – Uppdatera och distribuera om appen

  1. Öppna filen index.php i PHP-appen med ett lokalt textredigeringsprogram och gör små ändringar i texten i strängen bredvid echo:

    echo "Hello Azure!";
    
  2. Spara ändringarna och distribuera sedan om appen med kommandot az webapp up igen med följande argument:

    az webapp up --runtime "PHP:8.0" --os-type=linux
    
  3. När distributionen är klar går du tillbaka till webbläsarfönstret som öppnades när du skulle söka efter appen och klickar på knappen för att uppdatera sidan.

    Skärmbild av den uppdaterade exempelappen som körs i Azure.

4 – Hantera din nya Azure-app

  1. Gå till Azure Portal för att hantera den webbapp som du skapade. Sök efter och välj App Services.

    Skärmbild av Azure Portal med

  2. Välj namnet på din Azure-app.

    Skärmbild av App Services-listan i Azure. Namnet på demoapptjänsten är markerat.

    Webbappens översiktssida visas. Här kan du utföra grundläggande hanteringsuppgifter som Bläddra, Stoppa, Starta om och Ta bort.

    Skärmbild av App Service översiktssidan i Azure Portal. I åtgärdsfältet är knappgruppen Bläddra, Stoppa, Växla (inaktiverad), Starta om och Ta bort markerad.

    Webbappmenyn innehåller olika alternativ för att konfigurera din app.

5 – Rensa resurser

När du är klar med exempelappen kan du ta bort alla resurser för appen från Azure. Det medför inga extra avgifter och din Azure-prenumeration är inte rensad. Om du tar bort resursgruppen tas även alla resurser i resursgruppen bort och är det snabbaste sättet att ta bort alla Azure-resurser för din app.

Ta bort resursgruppen med hjälp av kommandot az group delete .

az group delete --name myResourceGroup

Det kan några minuter att köra kommandot.

Nästa steg