Hem Personliga finanser Hur man använder Apache Hadoop för prediktiv Analytics - dummies

Hur man använder Apache Hadoop för prediktiv Analytics - dummies

Video: How to Build and Install Hadoop on Windows 2024

Video: How to Build and Install Hadoop on Windows 2024
Anonim

Apache Hadoop är en fri, öppen källkodsplattform för skrivning och körning av program som behandlar en stor mängd data för prediktiv analys. Det möjliggör en distribuerad parallellbehandling av stora dataset som genereras från olika källor. I huvudsak är det ett kraftfullt verktyg för lagring och hantering av stora data.

Hadoop lagrar alla typer av data, strukturerad eller ostrukturerad, från olika källor - och aggregerar sedan data på nästan alla sätt du vill. Hadoop hanterar heterogen data med hjälp av distribuerad parallellbehandling - vilket gör det till en mycket effektiv ram för användning i analytisk programvara som hanterar stora data. Inte undra på att några stora företag antar Hadoop, inklusive Facebook, Yahoo!, Google, IBM, Twitter och LinkedIn.

Före Hadoop kunde företagen inte dra nytta av stora data, som inte analyserades och var nästan oanvändbara. Kostnaden för att lagra den data i en proprietär relationell databas och skapa ett strukturerat format kring det motiverade inte fördelarna med att analysera den data och utnyttja den.

Hadoop å andra sidan gör den uppgiften sömlös - till en bråkdel av kostnaden - så att företagen kan hitta värdefulla insikter i de rikliga uppgifterna de har förvärvat och samlar sig.

Hadops kraft ligger i att hantera olika typer - faktiskt vilken typ av data som helst: text, tal, e-post, foton, inlägg, tweets, du heter det. Hadoop tar hand om att aggregera denna data, i all sin sort, och ger dig möjlighet att fråga alla data när det är bekvämt.

Du behöver inte bygga ett schema innan du kan förstå dina data. Hadoop tillåter dig att fråga den data i sitt ursprungliga format.

Förutom att hantera stora mängder olika data, är Hadoop feltolerant, med hjälp av enkla program som hanterar schemaläggningen av bearbetningen fördelad över flera maskiner. Dessa program kan upptäcka maskinfel och vidarekoppla en uppgift till en annan körmaskin. Med detta arrangemang kan Hadoop leverera hög tillgänglighet, oavsett maskinvarufel.

Hadoop använder två huvudkomponenter (delprojekt) för att göra sitt jobb: MapReduce och Hadoop Distributed File System. De två komponenterna fungerar kooperativt:

  • MapReduce : Hadops implementering av MapReduce bygger på Googles forskning om programmeringsmodeller för att bearbeta stora dataset genom att dela dem i små arbetsblock. MapReduce använder distribuerade algoritmer, på en grupp datorer i ett kluster, för att bearbeta stora dataset.Den består av två funktioner:

    • Den Map () funktionen som ligger på mastern nod (nätverksdator). Det delar upp inmatningsfrågan eller uppgiften i mindre underrubriker, som den sedan distribuerar till arbetarknoder som behandlar de mindre uppgifterna och skickar svaren tillbaka till huvudnoden. Subtaskarna körs parallellt på flera datorer.

    • Funktionen Reduce () funktionen samlar resultaten från alla subtaskarna och kombinerar dem för att producera ett aggregerat slutresultat - vilket returneras som svar på den ursprungliga stora frågan.

  • Hadotes distribuerade filsystem (HDFS) : HDFS kopierar datablocken som finns på andra datorer i ditt datacenter (för att säkerställa tillförlitlighet) och hanterar överföringen av data till de olika delarna av ditt distribuerade system.

Tänk på en databas på två miljarder människor, och antar att du vill beräkna antalet X-sociala vänner och ordna dem enligt deras geografiska läge. Det är en lång order.

Uppgifterna för två miljarder människor kan härröra från mycket olika källor, till exempel sociala nätverk, e-postkontaktadresslistor, inlägg, tweets, surfhistoriker - och det är bara för öppnare. Hadoop kan aggregera denna enorma, varierande massa data så att du kan undersöka det med en enkel fråga.

Du skulle använda MapReduce programmeringsfunktioner för att lösa den här frågan. Definiera Map och Reducera procedurer gör att även denna stora dataset hanteras. Med hjälp av verktygen som Hadoop-ramverket erbjuder skulle du skapa ett MapReduce-genomförande som skulle göra beräkningen som två deltakare:

  • Beräkna det genomsnittliga antalet sociala vänner av Mr. X.

  • Ordna Mr Xs vänner genom geografiskt läge.

Ditt MapReduce-implementeringsprogram skulle köra dessa undertexter parallellt, hantera kommunikation mellan delarna och samla resultaten. Av två miljarder människor skulle du veta vem Mr. Xs online-vänner är.

Hadoop tillhandahåller en rad kartprocessorer; vilken (e) du väljer kommer att bero på din infrastruktur.

Var och en av dina processorer hanterar ett visst antal poster. Antag att varje processor hanterar en miljon dataposter. Varje processor utför en kartprocedur som producerar flera poster av nyckelvärdespar där G (nyckel) är den geografiska platsen en person (land) och N (värde) är antalet kontakter som personen har.

Antag att varje kartprocessor producerar många par av formuläret, till exempel följande:

Processor Map # 1:

Processor Map # 2:

Processor Map # 3:

Processor Map # 4:

Processor Map # 5:

Processor Map # 6:

I reduktionsfasen tilldelar Hadoop en uppgift till ett visst antal processorer: Utför Reduce-proceduren som aggregerar värdena för samma tangenter för att producera ett slutresultat. I det här exemplet summerar summan av värdet för varje nyckel - geografiskt läge. Så, efter Map-fasen, ger Reduce-fasen följande:

------ ----

Tydligt, Mr.X är en populär kille - men det var ett mycket enkelt exempel på hur MapReduce kan användas. Föreställ dig att du hanterar en stor dataset där du vill utföra komplexa aktiviteter som att klustra miljarder dokument där operationen och data är bara för stora för en enda maskin att hantera. Hadoop är verktyget att överväga.

Hur man använder Apache Hadoop för prediktiv Analytics - 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 ...