Gerenciamento de Disco e
de Buffer - Resumo
RESUMO DA AULA 2
Profa. Sandra de Amo
GBC053 – BCC
2012-2
Esquema Geral
Processador de Consultas
Solicita dados para consulta (leitura)
ou alterações (escritura)
Informa modif
Gerenciador de
Buffer
Propaga modif
aloca
Busca
DB
11/5/2015
Bacharelado em Ciência da Computação - 2012
2
Considere o seguinte cenário
Processador de Consultas
Solicita dados
para consulta (leitura)
Usuário consulta banco de dados
SELECT *
From EMP
WHERE EMP.CPF = 40333994598
11/5/2015
Gerenciador de
Buffer
Bacharelado em Ciência da Computação - 2012
3
Hipóteses
 Dados estão armazenados sequencialmente
no disco

na ordem em que foram inseridos
 Relação EMP está armazenada em um arquivo
de nome EMP.
 Existe um arquivo no disco onde se armazena, para cada arquivo,
o endereço no disco (cilindro, superficie, trilha, bloco) de sua
primeira página.
11/5/2015
Bacharelado em Ciência da Computação - 2012
4
O que faz o gerenciador de buffer (1)
 Verifica se a página 1 do arquivo EMP está no buffer pool e em
que frame.
 Caso positivo:

informa ao processador de consultas o frame onde se encontra a
página 1.
Incrementa pinout deste frame.
 Caso negativo: precisa encontrar espaço no buffer pool para
alocar página 1

11/5/2015
Bacharelado em Ciência da Computação - 2012
5
O que faz o gerenciador de buffer (2)
 Verifica se existem frames com pinout = 0
 Caso positivo: aciona gerenciador de disco





11/5/2015
Gerenciador de disco posiciona cabeça de leitura sobre a o
endereço da primeira página do arquivo EMP (conhecido do
gerenciador de buffer)
Gerenciador de disco providencia a transferência da página.
Gerenciador de buffer vai alocar a página em um frame com
pinout = 0
Qual frame será escolhido ?
 Usa sua politica de substituição (LRU, MRU, random)
Verifica o dirty bit deste frame
Bacharelado em Ciência da Computação - 2012
6
O que faz o gerenciador de buffer (3)
 Dirty bit = 1:
grava a página atual do frame no disco
 Aloca a nova página no frame
 Incrementa pinout do frame
 Retorna o endereço do frame para o processador de
consultas
 Dirty bit = 0:
 Aloca a nova página no frame
 Incrementa pinout do frame
 Retorna o endereço do frame para o processador de
consultas

11/5/2015
Bacharelado em Ciência da Computação - 2012
7
O que faz o gerenciador de buffer (4)
 Caso negativo: não existe nenhum frame com pinout = 0


11/5/2015
Gerenciador de buffer deve esperar até que um frame se
libere (pinout = 0)
Caso o tempo de espera ultrapasse um certo limite, envia
mensagem de erro para o processador de consultas.
Bacharelado em Ciência da Computação - 2012
8
Considere o seguinte cenário
Processador de Consultas
Solicita dados
para update (escrita)
Usuário consulta banco de dados
UPDATE EMP
SET EMP.NOME = `Carlos Martins’
WHERE EMP.CPF = `40322243289`
11/5/2015
Gerenciador de
Buffer
Bacharelado em Ciência da Computação - 2012
9
O que faz o gerenciador de buffer
 Executa os mesmos procedimentos feitos para o caso da
consulta.
 Após o processador de consultas executar a modificação na
página:


o dirty bit é atualizado para 1 (caso fosse 0 antes)
o dirty bit só é atualizado para 0 quando todas as transações que
usam esta página tenham entrado em commit e a página tenha
sido gravada em disco.
 Observação Importante:
 Antes de uma operação de escrita ou leitura ser executada em
uma página o Gerenciador de Transações é acionado.
 Protocolo de bloqueio é utilizado para dar permissão ao
processador de consultas de ler ou modificar a página.
11/5/2015
Bacharelado em Ciência da Computação - 2012
10
Download

Armazenamento - Sandra de Amo