Casa Finanza personale Come usare MapReduce per i Big Data - dummies

Come usare MapReduce per i Big Data - dummies

Sommario:

Video: Big Data in pillole da BrainWise 2024

Video: Big Data in pillole da BrainWise 2024
Anonim

MapReduce è una struttura software ideale per i big data perché consente agli sviluppatori di scrivere programmi in grado di elaborare enormi quantità di dati non strutturati in parallelo su un gruppo distribuito di processori.

La funzione mappa per i big data

La funzione mappa è stata una parte di molti linguaggi di programmazione funzionale per anni. La mappa è stata rinvigorita come tecnologia di base per elaborare elenchi di elementi di dati.

Gli operatori in linguaggi funzionali non modificano la struttura dei dati; creano nuove strutture di dati come output. Anche i dati originali non sono modificati. Quindi puoi usare la funzione mappa con impunità perché non danneggerà i tuoi preziosi dati memorizzati.

Un altro vantaggio della programmazione funzionale non è la necessità di gestire espressamente il movimento o il flusso dei dati. Questo assolve il programmatore dalla gestione esplicita dell'output e del posizionamento dei dati. Infine, l'ordine delle operazioni sui dati non è prescritto.

Un modo per raggiungere la soluzione è identificare i dati di input e creare un elenco:

mylist = ("tutte le contee negli Stati Uniti che hanno partecipato alle ultime elezioni generali") > Creare la funzione su comeMolte persone utilizzano la funzione mappa

. Seleziona solo le contee con più di 50.000 persone: mappa howManyPeople (mylist) = [howManyPeople "county 1"; howManyPeople "county 2"; howManyPeople "county 3"; howManyPeople "county 4"; …]

Ora produce un nuovo elenco di output di tutte le contee con popolazioni superiori a 50.000:

(no, contea 1; sì, contea 2; no, contea 3; sì, contea 4;?, Contea nnn)
La funzione viene eseguita senza apportare modifiche all'elenco originale. Inoltre, è possibile vedere che ogni elemento dell'elenco di output viene mappato a un elemento corrispondente dell'elenco di input, con un sì o nessun allegato. Se la contea ha soddisfatto il requisito di oltre 50.000 persone, la funzione mappa lo identifica con un sì. In caso contrario, viene indicato un no.

Aggiungi la funzione di riduzione per i big data

Come la funzione mappa,

riduce è stata una caratteristica dei linguaggi di programmazione funzionale per molti anni. La funzione reduce prende l'output di una funzione mappa e "riduce" l'elenco in qualsiasi modo desideri dal programmatore. Il primo passaggio richiesto dalla funzione di riduzione consiste nel posizionare un valore in qualcosa chiamato

accumulatore , che contiene un valore iniziale. Dopo aver memorizzato un valore iniziale nell'accumulatore, la funzione di riduzione elabora quindi ciascun elemento dell'elenco ed esegue l'operazione necessaria nell'intero elenco.

Alla fine dell'elenco, la funzione reduce restituisce un valore in base all'operazione che si desidera eseguire nell'elenco di output.

Supponiamo che sia necessario identificare le contee in cui la maggior parte dei voti era destinata al candidato democratico. Ricorda che la tua funzione mapManyPeople ha esaminato ogni elemento dell'elenco di input e creato un elenco di output delle contee con più di 50.000 persone (sì) e le contee con meno di 50.000 persone (no).

Dopo aver richiamato la funzione map di howManyPeople, ti rimane la seguente lista di output:

(no, contea 1; sì, contea 2; no, contea 3; sì, contea 4;?, county nnn)

Questo è ora l'input per la funzione di riduzione. Ecco come appare:

countylist = (no, contea 1; sì, contea 2; no, contea 3; sì, contea 4;?, Contea nnn): riduce isDemocrat (contea)

I processi di riduzione della funzione ogni elemento della lista e restituisce un elenco di tutte le contee con una popolazione superiore a 50.000, in cui la maggioranza ha votato democratico.

Mettere la mappa dei big data e ridurre insieme

A volte produrre un elenco di output è sufficiente. Allo stesso modo, a volte è sufficiente eseguire operazioni su ciascun elemento di una lista. Molto spesso, si desidera esaminare grandi quantità di dati di input, selezionare determinati elementi dai dati e quindi calcolare qualcosa di valore dalle relative parti di dati.

Non si desidera modificare l'elenco di input in modo da poterlo utilizzare in modi diversi con nuove ipotesi e nuovi dati.

Gli sviluppatori di software progettano applicazioni basate su algoritmi. Un algoritmo

non è altro che una serie di passaggi che devono essere eseguiti al servizio di un obiettivo generale. Potrebbe sembrare un po 'come questo: Inizia con un grande numero di dati o record.

  1. Iterate sui dati.

  2. Usa la funzione mappa per estrarre qualcosa di interessante e creare un elenco di output.

  3. Organizzare l'elenco di output per ottimizzare l'ulteriore elaborazione.

  4. Usa la funzione di riduzione per calcolare un insieme di risultati.

  5. Produce l'output finale.

  6. I programmatori possono implementare tutti i tipi di applicazioni usando questo approccio, ma gli esempi a questo punto sono stati molto semplici, quindi il valore reale di MapReduce potrebbe non essere evidente. Cosa succede quando hai dati di input estremamente grandi? Puoi usare lo stesso algoritmo su terabyte di dati? La buona notizia è sì.

Tutte le operazioni sembrano indipendenti. Questo perché lo sono. Il vero potere di MapReduce è la capacità di dividere e conquistare. Prendete un problema molto grande e spezzatelo in pezzi più piccoli, più gestibili, operate su ciascun blocco in modo indipendente e poi tiratelo tutti insieme alla fine. Inoltre, la funzione mappa è commutativa - in altre parole, l'ordine in cui una funzione viene eseguita non ha importanza.

Quindi MapReduce può eseguire il proprio lavoro su diversi computer in una rete. Può anche disegnare da più fonti di dati, interne o esterne. MapReduce tiene traccia del suo lavoro creando una chiave unica per garantire che tutto il processo sia correlato alla risoluzione dello stesso problema.Questo tasto viene anche utilizzato per riunire tutti gli output alla fine di tutte le attività distribuite.

Come usare MapReduce per i Big Data - dummies

Scelta dell'editore

Scattare foto digitali con uno zoom ottico - dummy

Scattare foto digitali con uno zoom ottico - dummy

La fotocamera digitale potrebbe avere uno zoom ottico, che è un Obiettivo zoom attuale vecchio stile (al contrario di uno zoom digitale). Per utilizzare lo zoom ottico della fotocamera digitale per scatti ravvicinati, segui questi passaggi di preparazione delle immagini prima di attivare il pulsante o lo switch di zoom:

La reflex digitale e la sensibilità alla luce - dummy

La reflex digitale e la sensibilità alla luce - dummy

La tua reflex digitale ha un'opzione per determinare la sensibilità del sensore della fotocamera è alla luce. Le fotocamere digitali sono le stesse delle fotocamere a pellicola in quanto la sensibilità alla luce è determinata dalla valutazione ISO. Il vantaggio di una fotocamera digitale è che non è necessario cambiare pellicola per modificare le valutazioni ISO. Quando aumenti ...

Scatti grandangolari con obiettivi standard - manichini

Scatti grandangolari con obiettivi standard - manichini

Fotografia grandangolare con un angolo di campo maggiore rispetto alla lunghezza focale normale o teleobiettivo. A volte si percepiscono le foto come molto espansive. Altre volte, a malapena lo si nota. Dipende tutto dal soggetto e da come si inquadra la scena. Questa figura mostra una scena di terreni agricoli che è stata scattata utilizzando un Sony APS-C ...

Scelta dell'editore

Come usare il meta tag DESCRIPTION - dummies

Come usare il meta tag DESCRIPTION - dummies

I meta tag sono tag HTML speciali che puoi utilizzare per trasportare informazioni, che i browser o altri programmi possono quindi leggere. Quando i motori di ricerca di Internet furono creati per la prima volta, i webmaster includevano i meta tag nelle loro pagine per rendere più facile per i motori di ricerca determinare le pagine. I motori di ricerca hanno utilizzato anche questi meta ...

Come scrivere un grande tag Title Web Marketing - dummies

Come scrivere un grande tag Title Web Marketing - dummies

Scrivere un tag title è fondamentale per il successo del web marketing e coinvolge più che mettere le parole chiave prima. I motori di ricerca mostrano il tag parola chiave nella parte superiore di ciascun elemento nelle pagine dei risultati dei motori di ricerca (SERP). Un tag del titolo ben scritto potrebbe aumentare le probabilità che un cliente in ricerca faccia clic sul tuo annuncio. Se ...

In che modo Yahoo! Cerca negli elenchi di Internet e dei ranghi - dummies

In che modo Yahoo! Cerca negli elenchi di Internet e dei ranghi - dummies

Quando le persone effettuano ricerche sul Web utilizzando Yahoo! , ottengono una combinazione di risultati organici e pagati. Se lavori per una società più grande, potresti provare Yahoo! La ricerca inoltra Pro per ottenere un vantaggio rispetto alla concorrenza e puoi persino registrare il tuo sito con Yahoo! Directory. Yahoo! I risultati di ricerca organica ...

Scelta dell'editore

Di Spotify su ShareMyPlaylists. it Funzionalità del sito - dummies

Di Spotify su ShareMyPlaylists. it Funzionalità del sito - dummies

ShareMyPlaylists (o SMP, in breve) è stato uno dei primi siti di condivisione di playlist Spotify e continua a innovare e offrire nuove funzionalità ai visitatori. Il mantra del sito è "Long Live the Mixtape", e qui troverai tantissime creazioni accuratamente compilate da migliaia di utenti. Dopo aver creato una playlist Spotify piena di ...

Spotify Unlimited - dummies

Spotify Unlimited - dummies

Spotify Unlimited è un modo brillante per ascoltare tutta la musica che vuoi senza limiti. È come una persona speciale che ti compra da mangiare e da bere tutta la sera per non doverti preoccupare del conto. È come essere in grado di dormire nel weekend senza preoccuparsi del lavoro o se ...

I generi di Spotify - dummies

I generi di Spotify - dummies

Che si tratti di hard rock, techno, pop, jazz, industrial, indie pop, folk , classico, heavy metal, valzer o qualsiasi altra cosa ti piaccia, Spotify ha il genere o il tipo di musica coperto. Puoi cercare i generi comuni da Spotify. Sebbene Spotify abbia pubblicato un elenco di quasi 1, 000 generi noti, non tutti saranno in grado di offrire ...