Livscykeln för Service Fabric-program
Precis som med andra plattformar går ett program i Azure Service Fabric vanligtvis igenom följande faser: design, utveckling, testning, distribution, uppgradering, underhåll och borttagning. Service Fabric ger förstklassigt stöd för hela programlivscykeln för molnprogram, från utveckling till distribution, daglig hantering och underhåll till eventuell avveckling. Tjänstmodellen gör det möjligt för flera olika roller att delta oberoende i programmets livscykel. Den här artikeln innehåller en översikt över API:erna och hur de används av de olika rollerna under faserna i Service Fabric-programmets livscykel.
På den här sidan finns en träningsvideo som beskriver hur du hanterar programmets livscykel:
Viktigt!
Det finns två CLI-verktyg som används för att interagera med Service Fabric. Azure CLI används för att hantera Azure-resurser, till exempel ett Azure-baserat Service Fabric-kluster. Service Fabric CLI används för att ansluta direkt till Service Fabric-klustret (oavsett var det finns) och hantera klustret, program och tjänster.
Tjänstmodellroller
Tjänstmodellrollerna är:
- Tjänstutvecklare: Utvecklar modulära och generiska tjänster som kan återanvändas och användas i flera program av samma typ eller olika typer. Till exempel kan en kötjänst användas för att skapa ett ärendeprogram (supportavdelningen) eller ett e-handelsprogram (kundvagn).
- Programutvecklare: Skapar program genom att integrera en samling tjänster för att uppfylla vissa specifika krav eller scenarier. En e-handelswebbplats kan till exempel integrera "JSON Stateless Front-End Service", "Auction Stateful Service" och "Queue Stateful Service" för att skapa en auktionslösning.
- Programadministratör: Fattar beslut om programkonfigurationen (fyller i parametrarna för konfigurationsmallen), distribution (mappning till tillgängliga resurser) och tjänstkvalitet. En programadministratör bestämmer till exempel språkspråket (engelska för USA eller japanska för Japan, till exempel) för programmet. Ett annat distribuerat program kan ha olika inställningar.
- Operator: Distribuerar program baserat på programkonfigurationen och kraven som angetts av programadministratören. Till exempel etablerar och distribuerar en operator programmet och ser till att det körs i Azure. Operatörer övervakar programhälsa och prestandainformation och underhåller den fysiska infrastrukturen efter behov.
Utveckla
- En tjänstutvecklare utvecklar olika typer av tjänster med hjälp av programmeringsmodellen Reliable Actors eller Reliable Services .
- En tjänstutvecklare beskriver de utvecklade tjänsttyperna i en tjänstmanifestfil som består av en eller flera kod-, konfigurations- och datapaket.
- En programutvecklare skapar sedan ett program med olika tjänsttyper.
- En programutvecklare beskriver deklarativt programtypen i ett programmanifest genom att referera till tjänstmanifesten för de konstituerande tjänsterna och på lämpligt sätt åsidosätta och parametrisera olika konfigurations- och distributionsinställningar för de ingående tjänsterna.
Se Kom igång med Reliable Actors och Kom igång med Reliable Services för exempel.
Distribuera
- En programadministratör anpassar programtypen till ett specifikt program som ska distribueras till ett Service Fabric-kluster genom att ange lämpliga parametrar för ApplicationType-elementet i programmanifestet.
- En operatör laddar upp programpaketet till klusteravbildningsarkivet med hjälp av metoden CopyApplicationPackage eller cmdleten Copy-ServiceFabricApplicationPackage. Programpaketet innehåller programmanifestet och samlingen av tjänstpaket. Service Fabric distribuerar program från programpaketet som lagras i avbildningsarkivet, som kan vara ett Azure-bloblager eller Service Fabric-systemtjänsten.
- Operatorn etablerar sedan programtypen i målklustret från det uppladdade programpaketet med hjälp av metoden ProvisionApplicationAsync, cmdleten Register-ServiceFabricApplicationType eller Rest-åtgärden Etablera ett program.
- När programmet har etablerats startar en operatör programmet med de parametrar som tillhandahålls av programadministratören med hjälp av metoden CreateApplicationAsync, cmdleten New-ServiceFabricApplication eller rest-åtgärden Create Application.
- När programmet har distribuerats använder en operatör metoden CreateServiceAsync, cmdleten New-ServiceFabricService eller åtgärden Create Service REST för att skapa nya tjänstinstanser för programmet baserat på tillgängliga tjänsttyper.
- Programmet körs nu i Service Fabric-klustret.
Se Distribuera ett program för exempel.
Test
- När du har distribuerat till det lokala utvecklingsklustret eller ett testkluster kör en tjänstutvecklare det inbyggda redundanstestscenariot med hjälp av klasserna FailoverTestScenarioParameters och FailoverTestScenario eller cmdleten Invoke-ServiceFabricFailoverTestScenario. Redundanstestscenariot kör en angiven tjänst genom viktiga övergångar och redundansväxlingar för att säkerställa att den fortfarande är tillgänglig och fungerar.
- Tjänstutvecklaren kör sedan det inbyggda kaostestscenariot med hjälp av klasserna ChaosTestScenarioParameters och ChaosTestScenario eller cmdleten Invoke-ServiceFabricChaosTestScenario. Scenariot med kaostestet inducerar slumpmässigt flera noder, kodpaket och replikfel i klustret.
- Tjänstutvecklaren testar tjänst-till-tjänst-kommunikation genom att redigera testscenarier som flyttar primära repliker runt klustret.
Mer information finns i Introduktion till tjänsten för felanalys.
Uppgradering
- En tjänstutvecklare uppdaterar de ingående tjänsterna i det instansierade programmet och/eller åtgärdar buggar och tillhandahåller en ny version av tjänstmanifestet.
- En programutvecklare åsidosätter och parameteriserar konfigurations- och distributionsinställningarna för de konsekventa tjänsterna och tillhandahåller en ny version av programmanifestet. Programutvecklaren införlivar sedan de nya versionerna av tjänstmanifesten i programmet och tillhandahåller en ny version av programtypen i ett uppdaterat programpaket.
- En programadministratör införlivar den nya versionen av programtypen i målprogrammet genom att uppdatera lämpliga parametrar.
- En operatör laddar upp det uppdaterade programpaketet till klusteravbildningsarkivet med hjälp av metoden CopyApplicationPackage eller cmdleten Copy-ServiceFabricApplicationPackage. Programpaketet innehåller programmanifestet och samlingen av tjänstpaket.
- En operator etablerar den nya versionen av programmet i målklustret med hjälp av metoden ProvisionApplicationAsync, cmdleten Register-ServiceFabricApplicationType eller REST-åtgärden Etablera ett program.
- En operatör uppgraderar målprogrammet till den nya versionen med hjälp av metoden UpgradeApplicationAsync, cmdleten Start-ServiceFabricApplicationUpgrade eller rest-åtgärden Uppgradera ett program.
- En operatör kontrollerar uppgraderingsförloppet med metoden GetApplicationUpgradeProgressAsync, cmdleten Get-ServiceFabricApplicationUpgrade eller REST-åtgärden Get Application Upgrade Progress.
- Vid behov ändrar och återställer operatorn parametrarna för den aktuella programuppgraderingen med hjälp av metoden UpdateApplicationUpgradeAsync, cmdleten Update-ServiceFabricApplicationUpgrade eller REST-åtgärden Uppdatera programuppgradering.
- Vid behov återställer operatorn den aktuella programuppgraderingen med hjälp av metoden RollbackApplicationUpgradeAsync, cmdleten Start-ServiceFabricApplicationRollback eller REST-åtgärden Rollback Application Upgrade.
- Service Fabric uppgraderar målprogrammet som körs i klustret utan att förlora tillgängligheten för någon av dess komponenter.
Se självstudien om programuppgradering för exempel.
Underhåll
- Service Fabric-gränssnitt med Azure-infrastrukturen för att garantera tillgängligheten för alla program som körs i klustret för operativsystemuppgraderingar och korrigeringar.
- För uppgraderingar och korrigeringar till Service Fabric-plattformen uppgraderar Service Fabric sig själv utan att förlora tillgängligheten för något av de program som körs i klustret.
- En programadministratör godkänner tillägg eller borttagning av noder från ett kluster efter analys av historiska kapacitetsanvändningsdata och beräknad framtida efterfrågan.
- En operatör lägger till och tar bort noder som angetts av programadministratören.
- När nya noder läggs till eller befintliga noder tas bort från klustret lastbalanserar Service Fabric automatiskt de program som körs över alla noder i klustret för att uppnå optimala prestanda.
Ta bort
- En operatör kan ta bort en specifik instans av en tjänst som körs i klustret utan att ta bort hela programmet med hjälp av metoden DeleteServiceAsync, cmdleten Remove-ServiceFabricService eller REST-åtgärden Delete Service.
- En operatör kan också ta bort en programinstans och alla dess tjänster med hjälp av metoden DeleteApplicationAsync, cmdleten Remove-ServiceFabricApplication eller rest-åtgärden Delete Application.
- När programmet och tjänsterna har stoppats kan operatorn avetablera programtypen med metoden UnprovisionApplicationAsync, cmdleten Unregister-ServiceFabricApplicationType eller avetablera en REST-åtgärd för programmet. Avetablering av programtypen tar inte bort programpaketet från ImageStore.
- En operator tar bort programpaketet från ImageStore med metoden RemoveApplicationPackage eller cmdleten Remove-ServiceFabricApplicationPackage.
Se Distribuera ett program för exempel.
Bevara diskutrymme i klusteravbildningsarkivet
ImageStoreService behåller kopierade och etablerade paket, vilket kan leda till ackumulering av filer. Filackumulering kan göra att ImageStoreService (fabric:/System/ImageStoreService) fyller disken och kan öka byggtiden för ImageStoreService-repliker.
Använd följande etableringssekvens för att undvika filackumulering:
Kopiera paketet till ImageStore och använd komprimeringsalternativet
Etablera paketet
Ta bort paketet i avbildningsarkivet
Uppgradera programmet/klustret
Avetablera den gamla versionen
Steg 3 och 5 i proceduren ovan förhindrar ackumulering av filer i avbildningsarkivet.
Konfiguration för automatisk rensning
Du kan automatisera steg 3 ovan med hjälp av PowerShell eller XML. Detta gör att programpaketet tas bort automatiskt efter den lyckade registreringen av programtypen.
Register-ServiceFabricApplicationTye -ApplicationPackageCleanupPolicy Automatic
XML:
<Section Name="Management">
<Parameter Name="CleanupApplicationPackageOnProvisionSuccess" Value="True" />
</Section>
Du kan automatisera steg 5 ovan med hjälp av XML. Detta gör att oanvända programtyper avregistreras automatiskt.
<Section Name="Management">
<Parameter Name="CleanupUnusedApplicationTypes" Value="true" />
<Parameter Name="PeriodicCleanupUnusedApplicationTypes" Value="true" />
<Parameter Name="TriggerAppTypeCleanupOnProvisionSuccess" Value="true" />
<Parameter Name="MaxUnusedAppTypeVersionsToKeep" Value="3" />
</Section>
Rensa filer och data på noder
Replikeringen av programfiler distribuerar slutligen filerna till alla noder beroende på balansåtgärder. Detta kan skapa disktryck beroende på antalet program och deras filstorlek. Även om ingen aktiv instans körs på en nod behålls filerna från en tidigare instans. Detsamma gäller för data från tillförlitliga samlingar som används av tillståndskänsliga tjänster. Detta tjänar syftet med högre tillgänglighet. Om det gäller en ny programinstans på samma nod får inga filer kopieras. För tillförlitliga samlingar måste endast deltat replikeras.
Om du vill ta bort programbinärfilerna helt måste du avregistrera programtypen.
Rekommendationer för att minska disktrycket:
- Remove-ServiceFabricApplicationPackage tar bort paketet från den tillfälliga uppladdningsplatsen.
- Avregistrera-ServiceFabricApplicationType frigör lagringsutrymme genom att ta bort programtypfilerna från avbildningslagringstjänsten och alla noder. Borttagningshanteraren körs varje timme per standard.
- CleanupUnusedApplicationTypes rensar gamla oanvända programversioner automatiskt.
{ "name": "Management", "parameters": [ { "name": "CleanupUnusedApplicationTypes", "value": true }, { "name": "MaxUnusedAppTypeVersionsToKeep", "value": "3" } ] }
- Remove-ServiceFabricClusterPackage tar bort gamla oanvända binärfiler för körningsinstallation.
Kommentar
En funktion är under utveckling så att Service Fabric kan ta bort programmappar när programmet har evakuerats från noden.
Nästa steg
Mer information om hur du utvecklar, testar och hanterar Service Fabric-program och -tjänster finns i: