- Vad är belastningstestning?
- Arkitektur för belastningstest
- Varför belastningstestning?
- Miljö
- Tillvägagångssätt
- Bästa praxis
- Slutsats
En komplett guide för belastningstestning för nybörjare:
I den här handledningen kommer vi att lära oss varför vi utför belastningstestning, vad man uppnår med det, arkitektur, vilket tillvägagångssätt som ska följas för att framgångsrikt utföra ett belastningstest, hur man sätter upp en belastningstestmiljö, bästa praxis och de bästa verktygen för belastningstestning som finns på marknaden.
Vi har hört talas om både funktionella och icke-funktionella testtyper. Inom icke-funktionell testning finns det olika typer av testning som prestandatester, säkerhetstestning, testning av användargränssnitt etc.
Lasttestning är därför en icke-funktionell typ av testning som är en delmängd av prestandatestning.
När vi säger att vi testar en applikations prestanda, vad testar vi då? Vi testar applikationen med avseende på belastning, volym, kapacitet, stress osv.
Vad är belastningstestning?
Belastningstestning är en delmängd av prestandatestning, där vi testar systemets respons under olika belastningsförhållanden genom att simulera att flera användare samtidigt använder programmet.
När vi ändrar belastningen övervakar vi systemets beteende under olika förhållanden.
Exempel : Låt oss anta att vår klients krav på en inloggningssida är 2-5 sekunder och att dessa 2-5 sekunder ska vara konsekventa hela tiden tills belastningen är 5000 användare. Så vad ska vi observera? Är det bara systemets förmåga att hantera belastningen eller är det bara kravet på svarstid?
Svaret är både och. Vi vill ha ett system som kan hantera en belastning på 5 000 användare med en svarstid på 2-5 sekunder för alla samtidiga användare.
Vad menas med en samtidig användare och en virtuell användare?
Samtida användare är de som loggar in i programmet och samtidigt utför en rad aktiviteter tillsammans och loggar ut ur programmet samtidigt. Virtuella användare å andra sidan hoppar bara in och ut ur systemet utan att ta hänsyn till andra användares aktiviteter.
Arkitektur för belastningstest
I diagrammet nedan kan vi se hur olika användare får tillgång till programmet. Här gör varje användare en förfrågan via internet, som sedan passerar genom en brandvägg.
Efter brandväggen har vi en lastbalansering som fördelar belastningen till någon av webbservrarna och sedan till applikationsservern och senare till databasservern där den hämtar nödvändig information baserat på användarens begäran.
Belastningstestning kan göras manuellt eller med hjälp av ett verktyg, men manuell belastningstestning rekommenderas inte eftersom vi inte testar programmet för en lägre belastning.
Exempel: Låt oss anta att vi vill testa en applikation för online shopping för att se applikationens svarstid för varje användarklick, dvs. steg 1 - Lansera URL, svarstiden, logga in i applikationen och notera svarstiden och så vidare, t.ex. välja en produkt, lägga till i kundvagnen, göra en betalning och logga ut. Allt detta måste göras för 10 användare.
När vi nu behöver testa applikationens belastning för 10 användare kan vi uppnå detta genom att manuellt lägga belastningen på 10 fysiska användare från olika maskiner i stället för att använda ett verktyg. I det här scenariot är det tillrådligt att välja ett manuellt belastningstest i stället för att investera i ett verktyg och konfigurera en miljö för verktyget.
Om vi däremot behöver testa belastningen för 1500 användare måste vi automatisera belastningstestet med hjälp av något av de tillgängliga verktygen baserat på den teknik som applikationen är byggd med och även baserat på den budget vi har för projektet.
Om vi har en budget kan vi välja kommersiella verktyg som Load runner, men om vi inte har så mycket budget kan vi välja verktyg med öppen källkod som JMeter osv.
Oavsett om det är ett kommersiellt verktyg eller ett verktyg med öppen källkod måste detaljerna delas med kunden innan vi färdigställer verktyget. Vanligtvis förbereds ett proof of concept där vi genererar ett provskript med verktyget och visar provrapporterna för kunden för godkännande av verktyget innan vi färdigställer det.
Vid automatiserad belastningstestning ersätter vi användarna med hjälp av ett automatiseringsverktyg som efterliknar användarnas handlingar i realtid. Genom att automatisera belastningen kan vi spara resurser och tid.
Nedan finns ett diagram som visar hur användarna byts ut med hjälp av ett verktyg.
Varför belastningstestning?
Låt oss anta att det finns en webbplats för online shopping som fungerar ganska bra under normala arbetsdagar, dvs. att användarna kan logga in i applikationen, bläddra bland de olika produktkategorierna, välja produkter, lägga till varor i kundvagnen, checka ut och logga ut inom ett acceptabelt intervall, och att det inte finns några sidfel eller enorma svarstider.
Under tiden kommer en toppdag, dvs. låt oss säga Thanks Giving-dagen, och det finns tusentals användare som är inloggade i systemet, systemet kraschar plötsligt och användarna upplever en mycket långsam respons, vissa kunde inte ens logga in på webbplatsen, några misslyckades med att lägga till i kundvagnen och några misslyckades med att checka ut.
Allt detta hände bara för att de inte förutsåg hur stor belastning användarna skulle få under toppdagarna, även om de skulle ha förutsett det hade det inte gjorts något belastningstest på företagets webbplats, och därför vet de inte hur stor belastning applikationen kommer att kunna hantera under toppdagarna.
För att hantera sådana situationer och för att övervinna stora intäkter är det lämpligt att genomföra belastningstester för sådana applikationer.
- Lasttestning hjälper till att bygga starka och tillförlitliga system.
- Flaskhalsen i systemet identifieras i god tid innan applikationen tas i drift.
- Det hjälper till att identifiera applikationens kapacitet.
Vad uppnås under ett belastningstest?
Med ett korrekt belastningstest kan vi få en exakt förståelse för följande:
- Det antal användare som systemet kan hantera eller kan skalas upp till.
- Svarstiden för varje transaktion.
- Hur beter sig varje komponent i hela systemet under belastning, dvs. applikationsserverkomponenter, webbserverkomponenter, databaskomponenter osv.
- Vilken serverkonfiguration är bäst för att hantera belastningen?
- Om den befintliga maskinvaran är tillräcklig eller om det finns behov av ytterligare maskinvara.
- Flaskhalsar som CPU-användning, minnesanvändning, nätverksfördröjningar etc. identifieras.
Miljö
Vi behöver en dedikerad belastningstestmiljö för att genomföra våra tester, eftersom belastningstestmiljön oftast är densamma som produktionsmiljön och de data som finns tillgängliga i belastningstestmiljön är desamma som i produktionen, även om det inte är samma data.
Det kommer att finnas flera testmiljöer som SIT-miljö, QA-miljö etc. Dessa miljöer är inte samma produktion, för till skillnad från belastningstestning behöver de inte så många servrar eller så mycket testdata för att utföra funktionstest eller integrationstest.
Exempel:
I en produktionsmiljö har vi tre applikationsservrar, två webbservrar och två databasservrar. I QA-miljön har vi bara en applikationsserver, en webbserver och en databasserver. Om vi utför ett belastningstest i QA-miljön, som inte är likvärdig med produktionsmiljön, är våra tester inte giltiga och felaktiga, och vi kan därför inte använda oss av dessa resultat.
Försök därför alltid att ha en särskild miljö för belastningstestning som liknar produktionsmiljön.
Ibland har vi också program från tredje part som vårt system anropar, och i sådana fall kan vi använda stubs eftersom vi inte alltid kan samarbeta med tredjepartsleverantörerna för att uppdatera data eller för andra frågor eller stöd.
Försök att ta en ögonblicksbild av miljön när den är klar, så att du kan använda ögonblicksbilden när du vill bygga om miljön, vilket underlättar tidshanteringen. Det finns en del verktyg som finns tillgängliga på marknaden för att konfigurera miljön, till exempel Puppet, Docker etc.
Tillvägagångssätt
Innan vi påbörjar belastningstestet måste vi förstå om något belastningstest redan har gjorts på systemet eller ej. Om det har gjorts något belastningstest tidigare måste vi veta hur lång svarstiden var, vilka klient- och servermätvärden som samlades in, hur stor kapacitet användaren hade osv.
Vi behöver också information om hur mycket den nuvarande applikationshanteringskapaciteten är. Om det är en ny applikation måste vi förstå kraven, vilken belastning som avses, vilken svarstid som förväntas och om det verkligen är möjligt att uppnå eller inte.
Om det är en befintlig applikation kan du få fram belastningskraven och användarnas åtkomstmönster från serverloggarna. Men om det är en ny applikation måste du vända dig till affärsteamet för att få all information.
När vi väl har fått fram kraven måste vi bestämma hur vi ska utföra belastningstestet. Görs det manuellt eller med hjälp av verktyg? Att göra ett belastningstest manuellt kräver mycket resurser och är också mycket dyrt. Det är också svårt att upprepa testet om och om igen.
För att lösa detta kan vi antingen använda verktyg med öppen källkod eller kommersiella verktyg. Verktyg med öppen källkod finns tillgängliga gratis, dessa verktyg har kanske inte alla funktioner som de kommersiella verktygen, men om projektet har en begränsad budget kan vi välja verktyg med öppen källkod.
De kommersiella verktygen har många funktioner, stöder många protokoll och är mycket användarvänliga.
Vårt tillvägagångssätt för belastningstesterna kommer att vara följande:
#1) Identifiera acceptanskriterierna för belastningstestet
Till exempel :
- Svarstiden för inloggningssidan bör inte vara längre än 5 sekunder även vid maximal belastning.
- CPU-användningen bör inte vara mer än 80 %.
- Systemets genomströmning bör vara 100 transaktioner per sekund.
#2) Identifiera de affärsscenarier som behöver testas.
Testa inte alla flöden, utan försök att förstå de viktigaste affärsflödena som förväntas ske i produktionen. Om det är en befintlig applikation kan vi få denna information från serverloggarna i produktionsmiljön.
Om det är en nybyggd applikation måste vi samarbeta med affärsteamen för att förstå flödesmönster, applikationsanvändning etc. Ibland kommer projektteamet att genomföra workshops för att ge en översikt eller detaljer om varje komponent i applikationen.
Vi måste delta i ansökningsworkshopen och notera all information som krävs för att genomföra vårt belastningstest.
#3) Modellering av arbetsbelastning
När vi har detaljerna om affärsflöden, användarnas åtkomstmönster och antalet användare måste vi utforma arbetsbelastningen på ett sådant sätt att den efterliknar den faktiska användarnavigationen i produktionen eller som den förväntas bli i framtiden när applikationen väl kommer att vara i produktion.
Det viktigaste att komma ihåg när man utformar en arbetsbelastningsmodell är att se hur lång tid det tar att slutföra ett visst affärsflöde. Här måste vi tilldela tanketiden på ett sådant sätt att användaren kan navigera i programmet på ett mer realistiskt sätt.
Arbetsbelastningsmönstret kommer vanligtvis att bestå av en upp- och nedtrappning och ett stabilt tillstånd. Vi bör långsamt belasta systemet och därför används upp- och nedtrappning. Det stabila tillståndet kommer vanligtvis att bestå av ett belastningstest på en timme med en upptrappning på 15 minuter och en nedtrappning på 15 minuter.
Låt oss ta ett exempel på arbetsbelastningsmodellen:
Översikt över applikationen - Låt oss anta att det handlar om en nätbutik, där användarna loggar in i applikationen och har ett stort antal klänningar att handla och kan navigera mellan varje produkt.
Om de vill se detaljerna om varje produkt måste de klicka på produkten. Om de gillar produktens pris och märke kan de lägga den i varukorgen och köpa produkten genom att checka ut och göra betalningen.
Nedan följer en lista över scenarier:
- Bläddra på - Här startar användaren applikationen, loggar in i applikationen, surfar genom olika kategorier och loggar ut ur applikationen.
- Bläddra, produktvisning, lägg till i kundvagnen - Här loggar användaren in i programmet, surfar genom olika kategorier, tittar på produktinformation, lägger produkten i varukorgen och loggar ut.
- Bläddra, visa produkter, lägg till i varukorgen och betala ut - I det här scenariot loggar användaren in i programmet, bläddrar genom olika kategorier, tittar på produktinformation, lägger produkten i vagnen, checkar ut och loggar ut.
- Bläddra, Visa produkter, Lägg till i varukorgen Kassa ut och gör betalning - Här loggar användaren in i programmet, surfar genom olika kategorier, tittar på produktdetaljer, lägger produkten i vagnen, checkar ut, betalar och loggar ut.
S.nr | Affärsflöde | Antal transaktioner | Virtuell användarbelastning | Svarstid (sek) | % tillåten felprocent | Transaktioner per timme |
---|---|---|---|---|---|---|
1 | Bläddra på | 17 | 1600 | 3 | Mindre än 2 % | 96000 |
2 | Bläddra, produktvisning, lägg till i kundvagnen | 17 | 200 | 3 | Mindre än 2 % | 12000 |
3 | Bläddra, visa produkter, lägg till i varukorgen och betala ut | 18 | 120 | 3 | Mindre än 2 % | 7200 |
4 | Bläddra, Visa produkter, Lägg till i varukorgen Kassa ut och gör betalning | 20 | 80 | 3 | Mindre än 2 % | 4800 |
Ovanstående värden har tagits fram på grundval av följande beräkningar:
- Transaktioner per timme = Antal användare*Transaktioner gjorda av en enskild användare under en timme.
- Antalet användare = 1600.
- Det totala antalet transaktioner i Browse-scenariot är 17.
- Svarstid för varje transaktion = 3.
- Total tid för en enskild användare att genomföra 17 transaktioner = 17*3 = 51 avrundat till 60 sekunder (1 minut).
- Transaktioner per timme = 1600*60 = 96000 transaktioner.
#4) Utforma belastningstesterna - Lasttestet bör utformas med hjälp av de uppgifter som vi hittills samlat in, dvs. affärsflöden, antal användare, användarmönster, mätvärden som ska samlas in och analyseras. Dessutom bör testerna utformas på ett mycket realistiskt sätt.
#5) Utför belastningstest - Innan vi utför belastningstestet ska vi se till att applikationen är igång. Belastningstestmiljön är klar. Applikationen har testats funktionellt och är stabil.
Kontrollera konfigurationsinställningarna för belastningstestmiljön. Den bör vara densamma som produktionsmiljön. Se till att alla testdata är tillgängliga. Se till att lägga till nödvändiga räknare för att övervaka systemets prestanda under testutförandet.
Börja alltid med en låg belastning och öka den gradvis. Börja aldrig med full belastning och bryt systemet.
#6) Analysera resultaten av belastningstestet - Gör ett baslinjetest för att alltid jämföra med andra testkörningar. Samla in mätvärden och serverloggar efter testkörningen för att hitta flaskhalsarna.
I vissa projekt används verktyg för övervakning av applikationsprestanda för att övervaka systemet under testkörningen, dessa APM-verktyg hjälper till att identifiera grundorsaken lättare och sparar mycket tid. Dessa verktyg är mycket lätta att hitta grundorsaken till flaskhalsen eftersom de har en bred bild för att lokalisera var problemet finns.
Några av APM-verktygen på marknaden är DynaTrace, Wily Introscope, App Dynamics etc.
#7) Rapportering - När testkörningen är avslutad samlar du in alla mätvärden och skickar en sammanfattande testrapport till det berörda teamet med dina observationer och rekommendationer.
Bästa praxis
Lista över verktyg för prestandatester som finns på marknaden för att utföra exklusiv belastningstestning.
Slutsats
I den här handledningen har vi lärt oss hur belastningstestning spelar en viktig roll i prestandatestning av en applikation, hur det hjälper till att förstå applikationens effektivitet och kapacitet osv.
Vi fick också veta hur den hjälper till att förutse om det krävs ytterligare hårdvara, programvara eller inställningar för en applikation.
Lycklig läsning!!