Informazioni Generali

Il corso copre un'ampia varietà di argomenti avanzati riguardanti il data intensive computing, inclusi i file system distribuiti, i database NoSQL, l'elaborazione di dati batch e streaming ed i sistemi per il machine learning distribuito.

Pagina su DidatticaWeb
Link per Microsoft Teams

CFU

6 CFU, 60 ore di didattica frontale distribuite in 4 ore a settimana.

Risultati dell'apprendimento

Principi, paradigmi e tecnologie per la progettazione e gestione di sistemi a larga scala che processano ed analizzano Big Data.

Prerequisiti

Il corso presuppone una conoscenza delle basi di dati, dei sistemi distribuiti e del Cloud computing.

Modalità di svolgimento delle lezioni

La didattica è svolta esclusivamente in presenza.
La classe virtuale su Teams è utilizzata per condividere il materiale del corso e per le informazioni.

Orario delle lezioni

Orario valido dal 3/3/2025 al 13/6/2025 (secondo semestre)
  • Lunedì dalle 11:30 alle 13:15, aula C5 edificio didattica
  • Giovedì dalle 11:30 alle 13:15, aula B8 edificio didattica

Docenti

Valeria Cardellini
Tel.: 067259 7388
E-mail: img (è necessario specificare [SABD] nell'oggetto della mail)
Ufficio: stanza D1-17, corpo D dell'edificio "Ingegneria dell'Informazione", primo piano.
Orario di ricevimento: in aula al termine delle lezioni oppure per appuntamento (contattare via email per concordare giorno e orario).

Matteo Nardelli
E-mail: (è necessario specificare [SABD] nell'oggetto della mail)
Orario di ricevimento: online, da concordare tramite email.



Materiale Didattico

Testi consigliati

Non c'è un libro di testo, in quanto il materiale si basa principalmente su articoli scientifici e documentazione dei framework e tool per Big Data.
Ma se sei interessata/o ad un testo, il seguente copre una buona parte degli argomenti trattati nel corso:

Slide delle lezioni

Argomento Lucidi Ultima modifica
Organizzazione del corso Organization.pdf 3/3/2025
Introduzione ai Big Data IntroBD.pdf 6/3/2025
Sistemi per storage dei dati Storage_DFS.pdf 10/3/2025
Data store NoSQL Storage_NoSQL.pdf 15/3/2025
Hands-on Hadoop Distributed File System
Storage_HandsOn_HDFS.pdf
scaletta
scripts_hdfs.zip
Docker Image Repository
17/3/2025
Hands-on NoSQL: Key-value - Redis Storage_HandsOn_NoSQL_KV.pdf
scaletta.txt
scripts_redis.zip
17/3/2025

Articoli

I seguenti articoli approfondiscono ed integrano gli argomenti trattati a lezione; la loro lettura è raccomandata.

When I talk to researchers, when I talk to people wanting to engage in entrepreneurship, I tell them that if you read research papers consistently, if you seriously study half a dozen papers a week and you do that for two years, after those two years you will have learned a lot. This is a fantastic investment in your own long term development. (Andrew Ng, Inside The Mind That Built Google Brain: On Life, Creativity, And Failure)

Introduzione ai Big Data

Storage: File System Distribuiti

Storage: Data store NoSQL e NewSQL

Video

Video di presentazioni utili per approfondire alcuni argomenti del corso.


Programma

  • Introduction to Big Data: issues and challenges
  • Data storage: distributed file systems, NoSQL data stores, NewSQL databases, time series databases
    • Case studies: GFS, HDFS, Dynamo, Bigtable, Cassandra, DynamoDB, Spanner, VoltDB
    • Lab: HDFS, Redis, MongoDB, HBase, Neo4j, InfluxDB, CockroachDB
  • Systems for data acquisition and ingestion: pub/sub, message queues, collection systems
    • Case studies: Kafka, Pulsar, Flume, and NiFi
  • Systems for batch processing
    • Case studies: Hadoop, Spark, Spark SQL, Spark MLlib
    • Lab: Spark, Spark SQL
  • Systems for stream processing
    • Case studies: Storm, Flink
    • Lab: Flink, Spark Streaming, Kafka Streams
    • Challenges in DSP
    • Runtime deployment in DSP (optional)
  • Batch and stream processing in the Cloud
  • Distributed and federated machine learning
    • Case studies: Spark MLlib, TensorFlow distributed

Esami

Modalità di esame

  1. 2 progetti assegnati durante il corso: il primo su batch processing, il secondo su data stream processing.
    Progetti da svolgere preferibilmente in gruppo composto da 2 o 3 studenti (singolarmente se non possibile altrimenti).
    Le tracce dei progetti sono pubblicate sul canale Teams del corso.
  2. Prova orale sul programma del corso.

Appelli

  • I appello sessione estiva
  • Prova orale: mercoledì 25 giugno 2025 ore 10:00, aula C3
  • II appello sessione estiva
  • Prova orale: martedì 15 luglio 2025 ore 10:00, aula B14