Hem Personliga finanser Map Phase of Hadops MapReduce Application Flow-dummies <[SET:descriptionsv]MapReduce-applikationsflödet

Map Phase of Hadops MapReduce Application Flow-dummies <[SET:descriptionsv]MapReduce-applikationsflödet

Video: Zoom Skills Pig UDF Demo 2024

Video: Zoom Skills Pig UDF Demo 2024
Anonim

En MapReduce-applikation behandlar data i ingångssplittor på en post-by-record -basis och att varje post förstås av MapReduce för att vara en nyckel / värde par. När inmatningsskivorna har beräknats kan mapparuppgifterna börja bearbeta dem - det vill säga direkt efter att resurschefens schemaläggningsfacilitet tilldelat dem sina bearbetningsresurser. (I Hadoop 1 tilldelar JobTracker mapperuppgifter till specifika bearbetningsplatser.)

I själva verket bearbetar mapper-uppgiften sin inmatningsdelad en post i taget - i figuren representeras denna lone rekord av nyckel / värdeparet. När det gäller våra flygdata, när inmatningsskivorna beräknas (med standardfilbehandlingsmetoden för textfiler) antas det att varje rad i textfilen är en enda post.

För varje post representerar texten i raden sig själva värdet, och byteförskjutningen för varje rad från början av delningen anses vara nyckeln.

Du kanske undrar varför radenummeret inte används istället för byteförskjutningen. När du anser att en mycket stor textfil är uppdelad i många enskilda datablock och bearbetas så många splittringar är radnumret ett riskabelt koncept.

Antalet rader i varje delning varierar, så det skulle vara omöjligt att beräkna antalet rader som föregår den som behandlas. Men med byteförskjutningen kan du vara exakt, för varje block har ett fast antal byte.

När en mappuppgift behandlar varje post genererar den ett nytt nyckel / värdepar: Nyckeln och värdet här kan vara helt annorlunda än ingångsparet. Utmatningen från mapparuppgiften är den fullständiga samlingen av alla dessa nyckel / värdepar.

Innan den slutliga utdatafilen för varje mappers uppgift skrivs ut delas utgången baserat på nyckeln och sorteras. Denna partition innebär att alla värden för varje nyckel grupperas ihop.

När det gäller den ganska grundläggande samplingsapplikationen finns det bara en enda reducerare, så all utmatning från mapper-uppgiften skrivs till en enda fil. Men i fall med multipla reducerare kan varje mapperuppgift generera flera utdatafiler också.

Uppdelningen av dessa utdatafiler är baserad på partitionsnyckeln. Om det till exempel bara finns tre separata partitioneringsnycklar för mapperuppgifterna och du har konfigurerat tre reducerare för jobbet, kommer det att finnas tre mapper-utdatafiler. I det här exemplet, om en viss mapper uppgift behandlar en ingångsdelning och det genererar output med två av de tre tangenterna, kommer det bara att finnas två utdatafiler.

Komprimera alltid dina mapperuppgifters utdatafiler. Den största fördelen här är prestationsvinster, eftersom skrivning av mindre utdatafiler minimerar den oundvikliga kostnaden för att överföra mapperutmatningen till de noder där reduktionsapparaten körs.

Standardpartitionern är mer än tillräcklig i de flesta situationer, men ibland kanske du vill anpassa hur data delas innan den bearbetas av reduktionsapparaten. Du kan till exempel vilja att data i dina resultatuppsättningar sorteras efter nyckeln och deras värden - känd som en sekundär sortering.

För att göra det kan du åsidosätta standardpartitionern och implementera din egen. Denna process kräver dock en viss omsorg, eftersom du vill se till att antalet poster i varje partition är enhetligt. (Om en reducerare måste bearbeta mycket mer data än de andra reduktionsmedlen, väntar du på att ditt MapReduce-jobb avslutas medan den enda överarbetade reduceraren slog genom sin oproportionerligt stora dataset.)

Använda mellanliggande filer med likformat storlek, du kan bättre utnyttja den parallellitet som finns tillgänglig i MapReduce-bearbetningen.

Map Phase of Hadops MapReduce Application Flow-dummies <[SET:descriptionsv]MapReduce-applikationsflödet

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 ...