Hem Personliga finanser Hur man optimerar MapReduce-uppdrag - dummies

Hur man optimerar MapReduce-uppdrag - dummies

Innehållsförteckning:

Video: Bästa sättet att optimera bilen. Part #1 2024

Video: Bästa sättet att optimera bilen. Part #1 2024
Anonim

Bortsett från att optimera den verkliga applikationskoden med MapReduce för stora dataprojekt kan du använda vissa optimeringstekniker för att förbättra tillförlitligheten och prestanda. De faller i tre kategorier: hårdvara / nätverkstopologi, synkronisering och filsystem.

Stor datahårdvara / nätverkstopologi

Oavsett tillämpning kommer den snabbaste hårdvaran och nätverken sannolikt att ge de snabbaste körtiderna för din programvara. En tydlig fördel med MapReduce är förmågan att köras på billiga kluster av råvara och standardnätverk. Om du inte uppmärksammar var dina servrar är fysiskt organiserade får du inte den bästa prestandan och hög grad av feltolerans som behövs för att stödja stora datauppgifter.

Varuhårdvara lagras ofta i rack i datacentret. Närheten till hårdvaran i racketet ger en prestandafördelning i motsats till att data flyttas och / eller kodas från rack till rack. Under implementeringen kan du konfigurera din MapReduce-motor för att vara medveten om och dra nytta av denna närhet.

Att hålla data och koden tillsammans är en av de bästa optimeringarna för MapReduce-prestanda. I huvudsak, ju närmare hårdvarubearbetningsdelarna är till varandra, desto mindre latens kommer du att behöva hantera.

Stor datasynkronisering

Eftersom det är ineffektivt att hålla alla resultat av din kartläggning inom noden kopierar synkroniseringsmekanismerna kartläggningsresultaten till de reducerande noderna omedelbart efter att de har slutförts så att bearbetning kan börja omedelbart. Alla värden från samma nyckel skickas till samma reducerare, vilket ger högre prestanda och bättre effektivitet.

Reduktionsutgångarna skrivs direkt till filsystemet, så det måste utformas och stämas för bästa resultat.

Stort datafilsystem

Ditt MapReduce-genomförande stöds av ett distribuerat filsystem. Den stora skillnaden mellan lokala och distribuerade filsystem är kapacitet. För att hantera enorma mängder information i en stor datavärld måste filsystem sprida sig över flera maskiner eller noder i ett nätverk.

MapReduce-implementeringar baserar sig på en distribution av master-slave, där huvudnoden lagrar alla metadata, åtkomsträttigheter, mappning och placering av filer och block, och så vidare. Slavarna är noder där de faktiska data lagras. Alla förfrågningar går till befälhavaren och hanteras sedan av lämplig slavnod.När du överväger utformningen av filsystemet bör du överväga följande:

  • Håll det varmt: Som du kanske förväntar dig kan huvudnoden bli överarbetad eftersom allt börjar där. Dessutom, om huvudnoden misslyckas, är hela filsystemet otillgängligt tills mastern återställs. En väldigt viktig optimering är att skapa en "warm standby" -nodenhet som kan komma igång om ett problem uppstår med onlinemästaren.

  • Ju större desto bättre: Filstorlek är också ett viktigt övervägande. Massor av små filer (mindre än 100 MB) bör undvikas. Distribuerade filsystem som stöder MapReduce-motorer fungerar bäst när de fylls med ett blygsamt antal stora filer.

  • Den långa vyn: Eftersom arbetsbelastningen hanteras i partier är höghållen nätverksbandbredd viktigare än snabb körningstider för mapprarna eller reducerarna. Det optimala sättet är att koden ska strömma mycket data när den läser och igen när det är dags att skriva till filsystemet.

  • Håll det säkert: Men inte alltför så. Lägga till lager av säkerhet på det distribuerade filsystemet kommer att försämra dess prestanda. Filbehörigheterna finns där för att skydda mot oavsiktliga konsekvenser, inte skadligt beteende. Det bästa sättet är att se till att endast behöriga användare har tillgång till datacenterets miljö och för att hålla det distribuerade filsystemet skyddat från utsidan.

Hur man optimerar MapReduce-uppdrag - 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 ...