Hem Personliga finanser Hur man använder MapReduce för stora data - dummies

Hur man använder MapReduce för stora data - dummies

Innehållsförteckning:

Video: Kenneth Cukier: Big data is better data 2025

Video: Kenneth Cukier: Big data is better data 2025
Anonim

MapReduce är en programvara ram som är idealisk för stora data eftersom det gör det möjligt för utvecklare att skriva program som kan bearbeta massiva mängder ostrukturerad data parallellt över en distribuerad grupp processorer.

Kortfunktionen för stora data

Funktionen map har varit en del av många funktionella programmeringsspråk i flera år. Kartan har nyinvesterats som en kärnteknik för behandling av listor med dataelement.

Operatörer på funktionella språk ändrar inte datastrukturen; de skapar nya datastrukturer som deras produktion. De ursprungliga uppgifterna är också omodifierade. Så du kan använda kartfunktionen med straffrihet eftersom det inte kommer att skada din värdefulla lagrade data.

En annan fördel med funktionell programmering behöver inte uttryckligen hantera dataens rörelse eller flöde. Detta frigör programmeraren från att explicit hantera datautgången och placeringen. Slutligen är ordningen för operationerna på data inte föreskriven.

Ett sätt att uppnå lösningen är att identifiera ingångsdata och skapa en lista:

mylist = ("alla län i oss som deltog i det senaste allmänna valet") > Skapa funktionen hurManyPeople använder kartfunktionen

. Detta väljer endast län med mer än 50 000 personer: karta howManyPeople (mylist) = [howManyPeople "county 1"; howManyPeople "county 2"; howManyPeople "county 3"; howManyPeople "county 4"; …]

Skapa nu en ny produktionslista över alla län med befolkningar över 50 000:

(nej, län 1, ja, län 2, nej, län 3, ja, län 4;?, Län nnn)
Funktionen exekveras utan att göra några ändringar i den ursprungliga listan. Dessutom kan du se att varje element i utmatningslistan kartlägger ett motsvarande element i inmatningslistan, med ja eller nej bifogad. Om länet har uppfyllt kravet på mer än 50 000 personer identifierar kartfunktionen det med ett ja. Om inte, anges nej.

Lägg till reduceringsfunktionen för stora data

Liksom kartfunktionen,

minska har funnits funktionella programmeringsspråk i många år. Reduktionsfunktionen tar utgången från en kartfunktion och "reducerar" listan på vilket sätt programmeraren önskar. Det första steget som reduceringsfunktionen kräver är att placera ett värde i något som kallas en

ackumulator , som har ett initialvärde. Efter lagring av ett startvärde i ackumulatorn bearbetar reduceringsfunktionen varje element i listan och utför den operation du behöver över listan.

I slutet av listan returnerar funktionen reducera ett värde baserat på vilken operation du vill utföra på utmatningslistan.

Antag att du måste identifiera länen där majoriteten av rösterna var för den demokratiska kandidaten. Kom ihåg att din howManyPeople-kartfunktion tittade på varje element i inmatningslistan och skapade en uttagslista över länen med mer än 50 000 personer (ja) och länen med mindre än 50 000 personer (nej).

Efter att ha aktiverat howManyPeople-kartfunktionen lämnas du med följande utmatningslista:

(nej, län 1; ja, län 2; nej, län 3; ja, län 4;, län nnn)

Detta är nu ingången för din reduceringsfunktion. Här ser du hur det ser ut:

countylist = (nej, län 1, ja, län 2, nej, län 3; ja, län 4;?, Län nnn) minska isDemocrat (countylist)

Minska funktionsprocesserna varje element i listan och returnerar en lista över alla län med en befolkning över 50 000, där majoriteten röstade demokratiska.

Sätta den stora datakartan och minska tillsammans

Ibland producerar en utmatningslista bara tillräckligt. På samma sätt är det ibland tillräckligt med operationer på varje element i en lista. Ofta vill du titta igenom stora mängder inmatningsdata, välja vissa element från data och sedan beräkna något av värde från relevanta data.

Du vill inte ändra den ingående listan så att du kan använda den på olika sätt med nya antaganden och nya data.

Programutvecklare utformar applikationer baserade på algoritmer. En

-algoritm är inget annat än en rad steg som måste uppstå i tjänsten till ett övergripande mål. Det kan se lite ut så här: Börja med ett stort antal eller data eller poster.

  1. Iterera över data.

  2. Använd kartfunktionen för att extrahera något av intresse och skapa en utdatarlista.

  3. Ordna utmatningslistan för att optimera för vidare bearbetning.

  4. Använd reduceringsfunktionen för att beräkna en uppsättning resultat.

  5. Producera slutprodukten.

  6. Programmerare kan implementera alla typer av applikationer med hjälp av detta tillvägagångssätt, men exemplen till denna punkt har varit mycket enkla, så det verkliga värdet av MapReduce kanske inte är uppenbart. Vad händer när du har extremt stora inmatningsdata? Kan du använda samma algoritm på data terabytes? Den goda nyheten är ja.

Alla verksamheter verkar oberoende. Det är för att de är. MapReduces verkliga kraft är förmågan att dela och erövra. Ta ett mycket stort problem och bryta det i mindre, mer hanterbara bitar, arbeta på varje bit självständigt och dra sedan allt ihop i slutet. Dessutom är kartfunktionen kommutativ - med andra ord, den ordning som en funktion utförs inte spelar någon roll.

Så MapReduce kan utföra sitt arbete på olika maskiner i ett nätverk. Det kan också dra från flera datakällor, internt eller externt. MapReduce håller reda på sitt arbete genom att skapa en unik nyckel för att säkerställa att all behandling är relaterad till att lösa samma problem.Denna nyckel används också för att dra all utdata tillsammans i slutet av alla distribuerade uppgifter.

Hur man använder MapReduce för stora data - dummies

Redaktörens val

Butik Stora data med HBase-dummies

Butik Stora data med HBase-dummies

HBase är en distribuerad, icke-relativ (kolumnär) databas som använder HDFS som dess uthållighet butik för stora dataprojekt. Den modelleras efter Google BigTable och kan ta emot mycket stora tabeller (miljarder kolumner / rader) eftersom den är lagrad på Hadoop-kluster av råvara. HBase tillhandahåller slumpmässig, realtid läs / skrivåtkomst till stora data. HBase ...

Strömmande algoritmer och blomfilters - dummies

Strömmande algoritmer och blomfilters - dummies

I hjärtat av många strömmande algoritmer är Bloom-filter. Skapat för nästan 50 år sedan av Burton H. Bloom, i en tid då datavetenskapen fortfarande var ganska ung, var den ursprungliga avsikten för denna algoritms skapare att handla utrymme (minne) och / eller tid (komplexitet) mot vad han kallade tillåtna fel. Hans ursprungliga papper heter ...

Lagring av data i Bigtables - dummies

Lagring av data i Bigtables - dummies

En Bigtable har tabeller precis som en RDBMS gör, men i motsats till en RDBMS, en Bigtable tabeller har i allmänhet inga relationer med andra tabeller. Istället grupperas komplexa data i ett enda bord. En tabell i en Bigtable består av grupper av kolumner, kallade kolumnfamiljer och en radnyckel. Dessa tillsammans möjliggör snabb uppslagning av ...

Redaktörens val

Bestämmer publiken för din finansiella modell - dummies

Bestämmer publiken för din finansiella modell - dummies

Som kommer att se eller använda din ekonomiska modell i framtiden ? Om det bara är för egen användning, bör du fortfarande följa bra modelldesign men det är inte nödvändigt att spendera mycket tid på formateringen så att den ser cool ut. Du borde fortfarande lägga till antaganden och källdokumentation för din egen ...

Radera celler och data i Excel 2007 - dummies

Radera celler och data i Excel 2007 - dummies

I Microsoft Office Excel 2007 när du behöver radera data , ta bort formatering i ett cellval, eller ta bort hela celler, rader eller kolumner, du har många alternativ beroende på ditt mål. Excel kan utföra två typer av cellborttagningar i ett kalkylblad: rensa celldata och radera cellen. Rensa cellinnehållet Rensa bara ...

Redigera en diagrams datakälla i Excel 2007 - dummies

Redigera en diagrams datakälla i Excel 2007 - dummies

Efter att du skapat ett diagram i Excel 2007 kan behöva byta intervallet för källdata som ligger till grund för diagrammet. Dialogrutan Välj datakälla låter dig välja ett annat källområde för ett befintligt diagram. Du kan även använda den här dialogrutan för att byta rad och ...

Redaktörens val

Praktiska Excel PivotTable Tools - dummies

Praktiska Excel PivotTable Tools - dummies

Excel PivotTables ger dig ett extremt kraftfullt verktyg för cross-tabulering av arbetsbladdata. Och kanske är det bara vad du förväntar dig av Microsoft och Excel. Men vet du vad? Jag antar att du kan bli förvånad över hur många verktyg som är enkla att använda visas på fliken PivotTable Tools Analyze, som är tillgänglig när ett pivottabell ...

Hur man får tillgång till vanliga redigeringskommandon i Excel 2007 - dummies

Hur man får tillgång till vanliga redigeringskommandon i Excel 2007 - dummies

Ibland vill du göra ändringar i information som du lägger in i Excel 2007-arbetsblad och arbetsböcker (kallas kalkylblad i världen utanför Excel). När så är fallet kan du använda de snygga nycklarna som är inbyggda i Excel 2007 eller komma åt kommandot via fliken Excel Ribbon som är nya i Excel 2007. För att få ...

Hur man får tillgång till vanliga Excel 2007-filkommandon - dummies

Hur man får tillgång till vanliga Excel 2007-filkommandon - dummies

Du kan köra Excel 2007s grundläggande filkommandon i två olika sätt: genom att trycka på en kombination av genvägar eller genom att klicka i Excel-bandet. Följande diagram visar några av de vanligaste filkommandon i Excel 2007 och de två sätten du kan komma åt dem: Excel-kommandotillgänglighetstangenter Funktion Microsoft ...