miércoles, 14 de marzo de 2018
martes, 13 de marzo de 2018
Estructura de la SGA.
Oracle utiliza la memoria para almacenar la siguiente información:
*Código del programa
*Información acerca de una sesión conectada, incluso si no se encuentra activa.
*Información necesaria durante la ejecución del programa(por ejemplo, el estado de las consultas)
*La información que comparten y con la cual se comunican los procesos Oracle (por ejemplo, la información de bloqueo)
*La Caché de Datos
La memoria se puede estructurar en las siguientes partes:
*Área Global del sistema (SGA), la cual se comparte entre todos los servidores y los procesos en segundo plano.
*Áreas globales de programas (PGA), que es privada para cada servidor y proceso en segundo planos; a cada proceso se asigna un PGA.
*Área de Ordenaciones (Sort Areas).
*Memoria Virtual
*Área de código de Software (SCA).
SGA de Base de datos:
SGA (Área Global del Sistema) es una estructura básica de memoria de Oracle que sirve para facilitar la transferencia de información entre usuarios y también almacena la información estructural de la BD más frecuentemente requerida.
El área global del sistema y un conjunto de procesos de la base de datos constituyen una instancia de una base de datos Oracle. La base de datos Oracle automáticamente reserva memoria para el área global del sistema cuando se inicia una instancia, y el sistema operativo reclama la memoria cuando se apaga dicha instancia. Cada instancia tiene su propia SGA.
su composicion es:
Buffer Redo Log:
Los registros Redo describen los cámbios realizados en la BD y son escritos en los ficheros redo log para que puedan ser utilizados en las operaciones de recuperación hacia adelante, roll-forward, durante las recuperaciones de la BD.
Los registros Redo describen los cámbios realizados en la BD y son escritos en los ficheros redo log para que puedan ser utilizados en las operaciones de recuperación hacia adelante, roll-forward, durante las recuperaciones de la BD.
Database Buffer Cache (Buffers de BD):
Es el caché que almacena los bloques de datos leidos de los segmentos de datos de la BD, tales como tablas, índices y clusters. Los bloques modificados se llamas bloques sucios. El tamaño de buffer caché se fija por el parámetro DB_BLOCK_BUFFERS.
Es el caché que almacena los bloques de datos leidos de los segmentos de datos de la BD, tales como tablas, índices y clusters. Los bloques modificados se llamas bloques sucios. El tamaño de buffer caché se fija por el parámetro DB_BLOCK_BUFFERS.
Shared SQL Pool (Área de SQL Compartido, ):
En esta zona se encuentran las sentencias SQL que han sido analizadas. El analisis sintáctico de las sentencias SQL lleva su tiempo y Oracle mantiene las estructuras asociadas a cada sentencia SQL analizada durante el tiempo que pueda para ver si puede reutilizarlas. Antes de analizar una sentencia SQL, Oracle mira a ver si encuentra otra sentencia exactamente igual en la zona de SQL compartido.
En esta zona se encuentran las sentencias SQL que han sido analizadas. El analisis sintáctico de las sentencias SQL lleva su tiempo y Oracle mantiene las estructuras asociadas a cada sentencia SQL analizada durante el tiempo que pueda para ver si puede reutilizarlas. Antes de analizar una sentencia SQL, Oracle mira a ver si encuentra otra sentencia exactamente igual en la zona de SQL compartido.
Arquitectura de un manejador de bases de datos (DBMS).
Memoria:
- Shared Global Area (SGA): es el área más grande de memoria y quizás el más importante
- Shared Pool: es una caché que mejora el rendimiento ya que almacena parte del diccionario de datos y el parsing de algunas consultas en SQL
- Redo Log Buffer: contiene un registro de todas las transacciones dentro de la base, las cuales se almacenan en el respectivo archivo de Redo y en caso de siniestro se vuelven a ejecutar aquellos cambios que aún no se hayan reflejado en el archivo de datos (commit).
- Large Pool: espacio adicional, generalmente usado en casos de multithreading y esclavos de I/O.
- Procesos:
- Threading
- System Monitor: despierta periódicamente y realiza algunas actividades entre las que se encuentran la recuperación de errores, recuperación de espacio libre en tablespaces y en segmentos temporales.
- Process Monitor: limpia aquellos procesos que el usuario termina de manera anormal, verificando consistencias, liberación de recursos, bloqueos.
- Database Writer: escribe bloques de datos modificados del buffer al disco, aquellas transacciones que llegan a un estado de commit.
- Log Writer: escribe todo lo que se encuentra en el redo log buffer hacia el redo file
Archivos:
- Control (ctl): almacenan información acerca de la estructura de archivos de la base.
- Rollback (rbs): cuando se modifica el valor de alguna tupla en una transacción, los valores nuevos y anteriores se almacenan en un archivo, de modo que si ocurre algún error, se puede regresar (rollback) a un estado anterior.
- Redo (rdo): bitácora de toda transacción, en muchos dbms incluye todo tipo de consulta incluyendo aquellas que no modifican los datos.
- Datos (dbf): el tipo más común, almacena la información que es accesada en la base de datos.
Tipos de instancias de un DBMS.
Online Transaction Processing (OLTP): compra/venta, telemarketing
- Segmentos cortos de rollback
- Shared Pool muy largo
- Redo log suficiente
- Indices en discos separados
- Segmentos temporales pequeños
Decision Support Systems (DSS): datawarehouse
- Segmentos largos de rollback
- Shared Pool relativamente corto
- Redo log suficiente
- Indices apropiados
- Segmentos largos de temporal
- Parallel Query en la medida de lo posible (si está disponible)
miércoles, 7 de marzo de 2018
componentes de un gestor de base de datos
Un SGBD está estructurado en diversos componentes software( o módulos), a cada uno de los cuales se les asigna una operación específica. Como hemos indicado anteriormente , algunas de las funciones del SGBD están soportadas por el sistema operativo subyacente . Sin embargo, el sistema operativo sólo proporciona servicios básicos y el SGBD debe diseñarse para funcionar encima suyo. Por tanto, el diseño de un SGBD debe tener en consideración la interfaz entre el SGBC y el sistema operativo.
Gestor de archivos:
Gestiona la asignación de espacio en la memoria del disco y de las estructuras de datos usadas para representar la información.
Manejador de base de datos:
Sirve de interfaz entre los datos y los programas de aplicación.
Procesador de consultas:
Traduce las proposiciones en lenguajes de consulta a instrucciones de bajo nivel. Además convierte la solicitud del usuario en una forma más eficiente.
Compilador de DDL:
Convierte las proposiciones DDL en un conjunto de tablas que contienen metadatos, estas se almacenan en el diccionario de datos.
Archivo de datos:
En él se encuentran almacenados físicamente los datos de una organización.
Diccionario de datos:
Contiene la información referente a la estructura de la base de datos.
Índices:
Permiten un rápido acceso a registros que contienen valores específicos.
Control de autorización:
Este módulo comprueba que el usuario tiene los permisos necesarios para llevar a cabo la operación que solicita.
Gestor de recuperación:
Este módulo garantiza que la base de datos permanece en un estado consistente en caso de que se produzca algún fallo.
Gestor de transacciones:
Este módulo realiza el procesamiento de las transacciones.
Convierte las proposiciones DDL en un conjunto de tablas que contienen metadatos, estas se almacenan en el diccionario de datos.
Archivo de datos:
En él se encuentran almacenados físicamente los datos de una organización.
Diccionario de datos:
Contiene la información referente a la estructura de la base de datos.
Índices:
Permiten un rápido acceso a registros que contienen valores específicos.
Control de autorización:
Este módulo comprueba que el usuario tiene los permisos necesarios para llevar a cabo la operación que solicita.
Gestor de recuperación:
Este módulo garantiza que la base de datos permanece en un estado consistente en caso de que se produzca algún fallo.
Gestor de transacciones:
Este módulo realiza el procesamiento de las transacciones.
Suscribirse a:
Entradas (Atom)
-
Oracle utiliza la memoria para almacenar la siguiente información: *Código del programa *Información acerca de una sesión conectada, in...
-
Ejemplo 1: # coding=utf-8 from turtle import * fi = 1.618033988749895 def cuadro(longitud): """Dibuja un cuadrado ...
-
MENÚ DE OPCIONES EN TURBO ASSEMBLE. pila segment stack 'stack' db 100h dup (?) pila ends datos segment tit...