Hem Personliga finanser Inmatning Splits i Hadops MapReduce - dummies

Inmatning Splits i Hadops MapReduce - dummies

Video: Create and Execute MapReduce in Eclipse 2024

Video: Create and Execute MapReduce in Eclipse 2024
Anonim

Hur HDFS har konfigurerats bryts ned mycket stora filer i stora block (till exempel, mäter 128 MB) och lagrar tre kopior av dessa block på olika noder i klustret. HDFS har ingen medvetenhet om innehållet i dessa filer.

I YARN, när ett MapReduce-jobb startas, resurshanteraren (klusterresurshanteringen och arbetsplaneringsfaciliteten) skapar en applikationsmastermonemon för att se efter livscykeln för jobbet. (I Hadoop 1 övervakade JobTracker enskilda jobb samt hantering av arbetsplanering och clusterresurshantering.)

> En av de första saker som Application Master gör är att avgöra vilka filblock som behövs för bearbetning. Application Master begär uppgifter från NameNode där replikerna av de nödvändiga datablocken lagras. Med hjälp av platsdata för filblocken Application Master gör förfrågningar till resursen Chef för att få kartuppgifter bearbetar specifika block på slavnoderna där de lagras.

Nyckeln till effektiv MapReduce-behandling är att så långt som möjligt bearbetas data lokalt - på slavnodet där den lagras. Innan du tittar på hur datablocken behandlas måste du titta närmare på hur Hadoop lagrar data. I Hadoop består filerna av enskilda poster, som i slutänden behandlas en-för-en av mapperuppgifter.

Exempelvis innehåller provdatasatsen information om färdiga flygningar i USA mellan 1987 och 2008.

För att hämta provdatasatsen, öppna Firefox-webbläsaren från VM och gå till Dataexpo-sidan.

Du har en stor fil för varje år, och inom varje fil representerar varje enskild linje en enda flygning. Med andra ord representerar en rad en post. Kom ihåg att blockstorleken för Hadoop-klustret är 64 MB, vilket innebär att de lätta datafilerna är brutna i bitar av exakt 64 MB.

Ser du problemet? Om varje kartuppgift behandlar alla poster i ett visst datablock, vad händer med de poster som spänner över blockgränser? Filblock är exakt 64 MB (eller vad du än bestämmer blockstorleken för), och eftersom HDFS inte har någon uppfattning om vad som finns i filblocken, kan det inte mäta när en skiva kan springa över i ett annat block.

För att lösa detta problem använder Hadoop en logisk representation av data lagrad i filblock, känd som

ingångsavsnitt . När en MapReduce-jobbklient beräknar ingångssplittningarna, räknas det ut var den första hela posten i ett block börjar och där den sista posten i blocket slutar. I de fall då den sista posten i ett block är ofullständig innehåller ingångssplitten platsinformation för nästa block och byteförskjutningen av de data som behövs för att slutföra posten.

Figuren visar detta samband mellan datablock och ingångsavsnitt.

Du kan konfigurera Application Master daemon (eller JobTracker, om du befinner dig i Hadoop 1) för att beräkna inmatningsavsnittet istället för jobbet klienten, vilket skulle vara snabbare för jobb som bearbetar ett stort antal datablock.

MapReduce databehandling drivs av detta koncept av ingångsavsnitt. Antalet ingångsavsnitt som beräknas för en specifik applikation bestämmer antalet mapparuppgifter. Var och en av dessa mapperuppgifter tilldelas, om möjligt, en slavnod där ingångsspliten lagras. Resurshanteraren (eller JobTracker, om du befinner dig i Hadoop 1) gör sitt bästa för att försäkra dig om att ingångssplittringar behandlas lokalt.

Inmatning Splits i Hadops MapReduce - 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 ...