Sistemas para Processamento de Big Data

Objetivos

Na UC será dado particular ênfase aos modelos programação suportados e à sua aplicação.

Os objetivos principais:

Conhecimento

  • Conhecer as diferentes facetas do processamento em Big Data
  • Conhecer as principais classes de sistemas para armazenamento de grandes volumes de dados
  • Conhecer os modelos de programação genéricos dominantes
  • Conhecer soluções para domínios específicos

Aplicação

  • Identificar qual o tipo de sistema apropriado para a resolução dum problema concreto
  • Codificar (a solução para) um problema concreto usando o modelo de programação mais adequado
  • Executar uma aplicação numa plataforma distribuída

Caracterização geral

Código

12078

Créditos

6.0

Professor responsável

João Manuel dos Santos Lourenço

Horas

Semanais - 4

Totais - 48

Idioma de ensino

Português

Pré-requisitos

 Conhecimentos de programação de computadores, preferencialmente em Python.

Conhecimento prévio de outras linguagens de programação como o C e Java são boas alternativas aos conhecimentos prévio de Python.

Bibliografia

Selected set of book chapters and papers -- these materials will be made available at CLIP.

Método de ensino

Nas aulas teóricas expõe-se e discutem-se os tópicos do programa da UC, recorrendo a sistemas existentes para ilustrar as questões em destaque. 

As aulas práticas fornecem aos alunos a experiência no desenvolvimento de soluções de processamento de dados em grande escala, usando uma seleção das plataformas existentes. São realizadas demonstrações, resolvidos exercícios e o acompanhamento dos dois pequenos trabalhos práticos a resolver durante o semestre.

A avaliação será baseada nos seguintes componentes: dois testes (25% cada); dois trabalhos de programação, resolvidos em grupo (15% + 35%).

Método de avaliação

2 testes (25%+25%) ou exame (50%)
– Classificação mínima (média dos dois testes ou exame) de 8,50 valores.

1 projeto de programação (50%)
– Grupos de 3 estudantes

Conteúdo

1. Visão Geral

  • Motivação, Aplicações
  • Desafios

2. Modelos de programação

  • Batch vs. Incremental vs. tempo-real
  • Dados estruturados vs. dados não-estruturados
  • Programação declarative vs. generalista

3. Armazenamento de Dados

  • Sistemas de ficheiros distribuídos (e.g. HDFS)
  • Base de dados relacionais.
  • Bases de dados NoSQL (e.g. key-value stores, arquivos de documentos)
  • Integração de múltiplas IGNOREes de dados (e.g. Hive)

4. Plataformas de processamento genéricas

  • Infraestrutura: contexto, propriedades e implicações
  • Modelo map-reduce and plataforma de suporte (e.g. Hadoop)
  • Plataformas de segunda geração (e.g Pig, Spark)

5. Processamento em domínios específicos

  • Bibliotecas para aprendizagem automatic (e.g. Spark MLlib)
  • Plataformas para processamento em grafos (e.g. GraphX)

6. Introdução às plataformas para processamento em tempo-real

  • Fontes de dados (e.g. Flume, Kafka)
  • Modelos de dados: micro-batches vs. fluxos contínuos
  • Plataformas de processamento (e.g. Storm, Spark Streaming)

Cursos

Cursos onde a unidade curricular é leccionada: