Hem Personliga finanser Shuffle-fasen av Hadops MapReduce Application Flow-dummies

Shuffle-fasen av Hadops MapReduce Application Flow-dummies

Video: Thorium. 2024

Video: Thorium. 2024
Anonim

Efter Map-fasen och före början av Reduce-fasen är en handoff-process, känd som shuffle och Sortera . Här utarbetas data från mapparuppgifterna och flyttas till noder där reduktionsuppgifterna ska köras. När mapper-uppgiften är klar sorteras resultaten efter nyckel, partitioneras om det finns flera reducerare och sedan skrivs till disken.

Du kan se detta koncept i följande figur, som visar MapReduce-databehandlingsflödet och dess interaktion med Hadoop-klustrets fysiska komponenter. (En snabb anteckning: Data i minnet representeras av vita rutor och data lagrad på disken representeras av grå rutor.)

För att påskynda den övergripande MapReduce-processen, flyttas data omedelbart till noden för reduktionsuppgifterna, för att undvika en översvämning av nätverksaktivitet när den slutliga mapperuppgiften avslutar sitt arbete. Överföringen händer när mapper-uppgiften körs, eftersom utmatningarna för varje post - kom ihåg - sparas i minnet av en väntande reduceringsuppgift. (Du kan konfigurera om detta händer - eller inte händer - och även antalet trådar som berörs.)

Tänk på att även om en reduceringsuppgift kan ha större delen av mapparens uppgift, kan processens bearbetning inte minska tills alla mappuppgifter har slutförts.

För att undvika scenarier där prestanda för ett MapReduce-jobb hämmas av en omedelbar mapparuppgift som körs på en dåligt fungerande slavnod, använder MapReduce-ramen ett koncept som heter spekulativt utförande .

Om vissa mappordningar löper långsammare än vad som anses rimligt, kommer Application Master att hämta duplicera uppgifter (i Hadoop 1 gör JobTracker det här). Oavsett vilken uppgift som avslutas först - dubbletter eller original - dess resultat lagras på disken och den andra uppgiften dödas. Om du övervakar dina jobb noggrant och undrar varför det finns fler mapperuppgifter som löper än du förväntar dig, är det en sannolik anledning.

Utmatningen från mapper-uppgifter är inte skriven till HDFS, utan snarare till lokal disk på slavnoden där mapper-uppgiften kördes. Som sådan replikeras det inte över Hadoop-klustret.

Bortsett från att komprimera utmatningen kan du potentiellt öka prestanda genom att köra en kombinationsuppgift. Denna enkla taktik, som visas här, innebär att man utför en lokal minskning av utmatningen för individuella mapperuppgifter.

I de flesta fall behövs ingen extra programmering, eftersom du kan berätta för systemet att använda reduktionsfunktionen. Om du inte använder din reduktionsfunktion, måste du se till att kombinationsfunktionens utgång är identisk med reducerfunktionen.

Det är upp till MapReduce-ramen om kombinationsfunktionen behöver köras en gång, flera gånger eller aldrig, så det är viktigt att combinerens kod säkerställer att slutresultatet inte påverkas av flera körningar. Att köra kombinationsmaskinen kan ge en prestanda genom att minska mängden mellanliggande data som annars skulle behöva överföras över nätverket.

Detta sänker också mängden bearbetning som reduktionsarbetet skulle behöva göra. Du kör en extra uppgift här, så det är möjligt att eventuell prestationsökning är försumbar eller kan till och med resultera i sämre övergripande prestanda. Din körsträcka kan variera, varför prova detta noggrant.

När alla resultat av mapperuppgifterna har kopierats till noden för reduktionsuppgifterna slås dessa filer samman och sorteras.

Shuffle-fasen av Hadops MapReduce Application Flow-dummies

Redaktörens val

Hur man lägger till text i en sätter () Funktion i C Programmering

Hur man lägger till text i en sätter () Funktion i C Programmering

När du behöver visa en annan textrad, använd C-programmeringsfärdigheterna för att skapa en annan puts () -funktion i källkoden, som visas i Visa två textlinjer. VISA TILL TEXTFINER # inkludera int main () {sätter ("Hickory, Dickory, Dock,"); sätter ("musen sprang klockan."); returnera (0);} Den andra ...

Förklarar variabler i C-dummies

Förklarar variabler i C-dummies

Variabler är det som gör dina program zooma. Programmering kan bara inte bli gjort utan dem. Så om du inte har introducerats till variabler än, här går du. Valerie Variable är en numerisk variabel. Hon älskar att hålla nummer - vilket nummer som helst; det spelar ingen roll. När hon ser ett lika tecken tar hon ett värde och ...

Redaktörens val

Gör rädsla för din vän - dummies

Gör rädsla för din vän - dummies

Rädsla är lika verklig som mod. Även om värdet av rädsla inte är lika uppenbart som modets värde, har det dess fördelar. Rädsla är din instinkt som säger att du är obehaglig - även om situationen inte kommer att skada dig. Alla har haft den känslan när man hellre drar locket ...

Hur man ökar din självmedvetenhet - dummies

Hur man ökar din självmedvetenhet - dummies

Du kommer att vara med dig själv under en livstid. Ingenting kommer att förändra det faktum. Att lära känna, som att lyssna på och uppskatta själv är avgörande för din sanity. Kanske kommer du till att älska, acceptera och omfamna alla du är, är svår för dig att föreställa dig just nu, men du kan göra ...

Hur man ökar din mentala flexibilitet - dummies

Hur man ökar din mentala flexibilitet - dummies

ÄR flexibel i arbete och relationer är ett tecken på en högpresterande. Medan perfektionister är styva och obehagliga i sitt arbete och hur de interagerar med andra, är högpresterande mer öppna och tillmötesgående. Att vara mer flexibel på jobbet gav Ralph aldrig förslag under brainstorming vid gruppmöten. Han kände att hans lag ...

Redaktörens val

Nätverksadministration: Linux-installation och virtuella konsoler - dummies

Nätverksadministration: Linux-installation och virtuella konsoler - dummies

Linux är i sig ett kommandoradsorienterat operativsystem. Grafiska användargränssnitt - inklusive installationsprogrammets GUI - tillhandahålls av en valfri komponent som heter X Window System. Men medan du arbetar med det grafiska användargränssnittet för installationsprogrammet, håller Linux flera ytterligare kommandorads-konsoler öppna. Normalt behöver du inte ...

Nätverksadministration: Linux-loggning, logg och systemavstängning - dummies

Nätverksadministration: Linux-loggning, logg och systemavstängning - dummies

Alla användare som åtkomst ett Linux-system, lokalt eller över ett nätverk, måste verifieras av ett giltigt användarkonto på systemet. I det följande får du veta hur du loggar in och ut på ett Linux-system och hur du stänger av systemet. Logga in När Linux startar upp visas det ...

Nätverksadministration: Licensserver - Dummies

Nätverksadministration: Licensserver - Dummies

I vissa program kan du köpa nätverkslicenser som gör att du kan installera programvaran på många datorer som du vill, men reglera antalet personer som kan använda programvaran vid en viss tidpunkt. För att styra hur många som använder programvaran, är en särskild licensserver inrättad. När en användare börjar ...