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