1. Universidad Tecnológica Israel Facultad de Ingeniería en Sistemas Administración de base de datos SINED 9no Nivel Magdalena Chicaiza Acosta
2. Contenido Introducción Tareas del Administrador de la Base de Datos Componentes Principales Establecimiento de una Conexión y Creación de una Sesión Base de Datos Oracle. Estructura Física. Estructura Lógica.
3. INTRODUCCIONORACLE.- Es una base de datos de objetos relacionales escalable y fácil de gestionar . Particionamiento : Permite controlar las tablas y los índices con un nivel de granularidad inferior Real ApplicationClusters: permite que múltiples instancias del software de Oracle accedan a una única base de datos . Paquetes de Oracle Enterprise Manager: son herramientas para una gestión de cambios, un ajuste, un control y un diagnóstico avanzados de los entornos de Oracle. Seguridad avanzada: Proporciona seguridad mediante el cifrado y la comprobación de la integridad de datos y soporta servicios de autenticación de usuario mejorados con servicios de seguridad de terceros.
4. TAREAS DEL ADMINISTRADOR DE BDDUn DBA es el responsable de mantener el Oracle Server operativo ante las peticiones de los usuarios. Entre sus principales tareas esta: Planificar y crear bases de datos Gestionar la disponibilidad de la base de datos Gestionar las estructuras físicas y lógicas Gestionar el almacenamiento basándose en el diseño Gestionar la seguridad Administración de la red Copia de seguridad y recuperación Ajuste de la base de datos
5. COMPOPNENTES PRINCIPALES Instancia Oracle es la combinación de los procesos en segundo plano y las estructuras de memoria. Los procesos de usuario y de servidor son los procesos principales implicados en la ejecución de una sentencia SQL. Base de datos Oracle: Una base de datos Oracle está formada por archivos del sistema operativo que se utilizan para asegurar la consistencia de los datos, así como su recuperación en caso de que se produzca un fallo de la instancia.
6. ESTABLECIMIENTO DE UNA CONEXIÓN Y CREACIÓN DE UNA SESIÓN El usuario inicia una herramienta como SQL*Plus , se crea un proceso en el equipo que ejecuta Oracle Server. El proceso de servidor ejecuta las sentencias SQL en nombre del usuario. El proceso de servidor se comunicará con la instancia Oracle en nombre del proceso de usuario en el cliente.
7. ESTABLECIMIENTO DE UNA CONEXIÓN Y CREACIÓN DE UNA SESIÓN Conexión .- es la ruta de comunicación entre un proceso de usuario y Oracle Server. Existen tres formas: El usuario se conecta al sistema operativo ejecutando la instancia Oracle donde la conexión se establece mediante los mecanismos de comunicación entre procesos disponibles en el sistema operativo del host. El usuario inicia la aplicación o la herramienta en un equipo local, aquí el software de red se utiliza para establecer la comunicación entre el usuario y Oracle Server. (Cliente - Servidor) En una conexión de tres capas, el equipo del usuario se comunica a través de la red con un servidor de aplicaciones o de red, que se conecta a través de una red a la máquina que ejecuta la instancia Oracle. Sesiones.- Una sesión es una conexión específica de un usuario a Oracle Server. La sesión se inicia cuando Oracle Server valida al usuario, y finaliza cuando el usuario se desconecta
8. BASE DE DATOS ORACLE El objetivo general de una base de datos es el de almacenar y recuperar la información relacionada. Una base de datos Oracle tiene una estructura lógica y una física. Una base de datos Oracle consta de tres tipos de archivos. Los archivos de datos que contienen los datos reales de la base de datos Los archivos redo log que contienen un registro de los cambios efectuados en la base de datos para activar la recuperación de los datos en caso de fallos Los archivos de control que contienen la información necesaria para mantener y verificar la integridad de la base de datos
9. BASE DE DATOS ORACLE Otras Estructuras de Archivos Clave Oracle Server también utiliza otros archivos que no forman parte de la base de datos: El archivo de parámetros define las características de una instancia Oracle. Por ejemplo, contiene los parámetros que especifican el tamaño de las estructuras de la memoria en el SGA. El archivo de contraseñas autentica los usuarios con privilegios para iniciar y cerrar una instancia Oracle. Los archivos redo log archivados son copias offline de los archivos redo log online que pueden ser necesarios para recuperarse de los fallos del medio físico.
10. ESTRUCTURA FISICA La estructura física incluye tres tipos de archivos de control, de datos y redo log online. Estructura de la memoria La estructura de la memoria de Oracle está formada por dos áreas de memoria llamadas: SGA (Área Global del Sistema): Asignada al iniciar la instancia y componente fundamental de una instancia Oracle PGA (Área Global de Programas): Asignada al iniciar el proceso de servidor
11. ESTRUCTURA FISICA Área global del sistema.- Se utiliza para almacenar información de base de datos que comparten los procesos de base de datos. El área SGA está formada por varias estructuras de la memoria: – Conjunto Compartido (Sharedpool ) – Caché de Buffers de Base de Datos – Buffer de Redo Log – Otras estructuras (por ejemplo, gestión de bloqueos y bloqueos internos, datos estadísticos)
12. ESTRUCTURA FISICA Conjunto Compartido.- Se utiliza para almacenar las últimas sentencias SQL ejecutadas y las últimas definiciones de datos utilizadas y esta formado por el Caché de Biblioteca y el Caché del Diccionario de Datos. La asignación de memoria del conjunto compartido se determina por el parámetro de inicialización SHARED_POOL_SIZE. El tamaño se puede cambiar de forma dinámica mediante ALTER SYSTEM SET. Caché de Biblioteca .- Permite almacenar información acerca de las sentencias SQL y PL/SQL utilizadas más recientemente. Esta formado por el Área de SQL compartido (Almacena y comparte el plan de ejecución y el árbol de análisis para las sentencias SQL que se ejecutan en la base de datos) y el Área de PL/SQL compartido (Almacena y comparte las sentencias PL/SQL ejecutadas más recientemente). La memoria se asigna al analizar una sentencia o al llamar a una unidad de programa. Caché del Diccionario de Datos.- En este espacio de memoria se almacena el conjunto de las definiciones utilizadas más recientemente en la base de datos, El tamaño total depende del tamaño del conjunto compartido y lo gestiona de forma interna la base de datos.
13. ESTRUCTURA FISICA Caché de Buffers de Base de Datos.- En este espacio de memoria se almacena copias de bloques de datos que se han recuperado de archivos de datos. Cuando se procesa una consulta, el proceso de Oracle Server busca en la caché de buffers de base de datos los bloques que necesita. Oracle Server utiliza un algoritmo LRU para los buffers obsoletos a los que no se ha accedido recientemente con el fin de dejar sitio a los nuevos bloques en la caché de buffers de base de datos. Está formado por subcachés independientes: DB_CACHE_SIZE, DB_KEEP_CACHE _SIZE, DB_RECYCLE_CACHE_SIZE. El tamaño de cada buffer de la caché de buffers de base de datos equivale al tamaño de un bloque Oracle, y lo especifica el parámetro DB_BLOCK_SIZE.
14. ESTRUCTURA FISICA Los Valores del Parámetro DB_CACHE_ADVICE OFF: El asesor está desactivado y no se le asigna memoria. ON: El asesor está activado y se produce una sobrecarga tanto de CPU como de memoria. La función Asesor de Caché de Buffers activa y desactiva la recopilación de estadísticas para predecir el comportamiento de los distintos tamaños de caché. Buffer de Redo Log.- En este espacio se registra todos los cambios realizados en los bloques de datos de la base de datos, su finalidad principal es la recuperación, los cambios registrados dentro de éste se llaman registros de redo, los registros de redo contienen información que permite reconstruir o rehacer cambios, el tamaño está definido por LOG_BUFFER. El tamaño del buffer de redo log está definido por el parámetro de inicialización LOG_BUFFER.
15. ESTRUCTURA FISICA Conjunto Grande.- Es un área opcional de memoria en el SGA que permite liberar al conjunto compartido de su carga, se utiliza para: Memoria de sesión (UGA) para el servidor compartido Procesos de servidor de E/S Operaciones de copia de seguridad y recuperación o RMAN Buffers de mensajes de ejecución en paralelo: PARALLEL_AUTOMATIC_TUNING se define como TRUE RMAN (Oracle Recovery Manager) utiliza el conjunto grande cuando se definen los parámetros BACKUP_DISK_IO=n y BACKUP_TAPE_IO_SLAVE= TRUE. Si se ha configurado el conjunto grande, pero no tiene el tamaño suficiente, fallará la asignación de la memoria del conjunto grande. El tamaño del conjunto grande se especifica en bytes definidos por el parámetro LARGE_POOL_SIZE.
16. ESTRUCTURA FISICA SGA Dinámica.- A partir de Oracle9i, el área SGA dinámica implementa una infraestructura que permite modificar la configuración del SGA sin cerrar la instancia. El tamaño del área SGA lo determinan varios parámetros de inicialización estos son: DB_CACHE_SIZE (Tamaño de la caché de bloques estándar), LOG_BUFFER (Número de bytes asignados al buffer de redo log) , SHARED_POOL_SIZE (Tamaño en bytes del área dedicada a SQL compartido y a PL/SQL), LARGE_POOL_SIZE (Tamaño del conjunto grande), JAVA_POOL_SIZE(Tamaño del conjunto Java). Conjunto Java.- Requisitos de análisis de servicios para comandos Java, es necesario si se instala y se utiliza Java, su tamaño está definido por el parámetro JAVA_POOL_SIZE.
17.
18.
19. ESTRUCTURA FISICA Estructura de Procesos Oracle se beneficia de varios tipos de procesos: Procesos de usuario: Se inician cuando un usuario de base de datos solicita una conexión a Oracle Server Procesos de servidor: Se conectan a la instancia Oracle y se inician cuando un usuario establece una sesión. Procesos en segundo plano: Se inician al iniciar una instancia Oracle
20.
21. El número de buffers sucios alcanza un valor umbral.
22. Un proceso explora un número determinado de bloques cuando realiza una exploración en busca de buffers libres y no puede encontrar ninguno.
29. Cuando el buffer de redo log se encuentra a un tercio de su capacidad.
30. Cuando existe más de un megabyte de cambios en el buffer de redo log.
31. Antes de que DBWn escriba los bloques modificados de la caché de buffers de base de datos en los archivos de datos.
32.
33. ESTRUCTURA FISICA PMON (Monitor de Procesos) Hace una limpieza cuando los procesos han fallado: Haciendo un rollback en las transacciones Liberando los bloqueos Liberando otros recursos Reiniciando distribuidores interrumpidos El proceso en segundo plano PMON realiza una limpieza después de los procesos fallidos de la siguiente forma: Realizando rollback en la transacción actual del usuario Liberando todos los bloqueos de tablas o filas actuales Liberando otros recursos que están reservados en ese momento por el usuario Reiniciando distribuidores interrumpidos
34. ESTRUCTURA FISICA CKPT (Punto de Control).- Responsable de: Señalar a DBWn en los puntos de control Actualizar las cabeceras de archivos de datos con información del punto de control Actualizar los archivos de control con información del punto de control Los puntos de control se inician por los siguientes motivos: Para garantizar que los bloques de datos modificados en la memoria se escriben en el disco con frecuencia, de forma que no se pierdan en caso de que se produzca el fallo de un sistema o de una base de datos. Para reducir el tiempo necesario de recuperación de una instancia. Para la recuperación, sólo es necesario procesar las entradas del archivo redo log online posteriores al último punto de control. Para garantizar que todos los datos validados se han escrito en los archivos de datos durante el cierre.
35. ESTRUCTURA FISICA CKPT (Punto de Control).- Responsable de: Señalar a DBWn en los puntos de control Actualizar las cabeceras de archivos de datos con información del punto de control Actualizar los archivos de control con información del punto de control Los puntos de control se inician por los siguientes motivos: Para garantizar que los bloques de datos modificados en la memoria se escriben en el disco con frecuencia, de forma que no se pierdan en caso de que se produzca el fallo de un sistema o de una base de datos. Para reducir el tiempo necesario de recuperación de una instancia. Para la recuperación, sólo es necesario procesar las entradas del archivo redo log online posteriores al último punto de control. Para garantizar que todos los datos validados se han escrito en los archivos de datos durante el cierre.
36. ESTRUCTURA FISICA ARCn (Archiver).- • Proceso opcional en segundo plano • Archiva automáticamente archivos redo log online si está definido el modo ARCHIVELOG • Protege el registro contra todos los cambios realizados en la base de datos Archivado de los Archivos Redo Log Online.- Una de las decisiones importantes que debe tomar un DBA es si debe configurar la base de datos para que funcione en modo ARCHIVELOGo en modo NOARCHIVELOG. Modo NOARCHIVELOG.- En este modo, los archivos redo log online se sobrescriben cada vez que se produce un cambio de log. Modo ARCHIVELOG.- En caso de que la base de datos se configure para que se ejecute en modo ARCHIVELOG, será necesario archivar los grupos inactivos de archivos redo log online llenos antes de que se puedan volver a utilizar de nuevo.
37. ESTRUCTURA LOGICA Establece el modo de uso del espacio físico de una base de datos respetando la Jerarquía formada por tablespaces, segmentos, extensiones y bloques. Existe la siguiente jerarquía de estructuras lógicas: Una base de datos Oracle contiene como mínimo un tablespace. Un tablespace contiene uno o más segmentos. Cada segmento está formado por extensiones. Una extensión está formada por bloques lógicos. Un bloque es la unidad más pequeña para las operaciones de lectura y escritura.
38. ESTRUCTURA LOGICA Tablespaces.- Los datos de una base de datos Oracle se almacenan en tablespaces. Una base de datos Oracle se puede agrupar de forma lógica en áreas lógicas más pequeñas de espacio conocidas como tablespaces. Un tablespace sólo puede pertenecer a una base de datos a la vez. Cada tablespace está formado por uno o más archivos del sistema operativo, que reciben el nombre de archivos de datos. Un tablespace puede tener uno o más segmentos. Los tablespaces se pueden poner en línea mientras se está ejecutando la base de datos. Excepto en el caso del tablespaceSYSTEMo un tablespace con un segmento de deshacer activo, los tablespaces se pueden poner offline y dejar que la base de datos se siga ejecutando. Los tablespaces pueden cambiar entre un estado de lectura y escritura y de sólo lectura.
39. ESTRUCTURA LOGICA Archivos de Datos (Estructura No Lógica): Cada tablespace de una base de datos Oracle está formado por uno o más archivos llamados archivos de datos. Se trata de estructuras físicas que se ajustan al sistema operativo en el que se ejecuta Oracle Server. Un archivo de datos sólo puede pertenecer a un tablespace. Oracle Server crea un archivo de datos para un tablespace asignando la cantidad especificada de espacio en disco más una pequeña cantidad de sobrecarga. El administrador de la base de datos puede cambiar el tamaño de un archivo de datos una vez creado, o bien puede especificar que un archivo debería aumentar dinámicamente a medida que aumentan los objetos en el tablespace.
40. ESTRUCTURA LOGICA Segmentos.- Un segmento es el espacio asignado a una estructura de almacenamiento lógica específica dentro de un tablespace. Un tablespace puede estar formado por uno o más segmentos. Un segmento no puede abarcar tablespaces; sin embargo, un segmento puede abarcar múltiples archivos de datos que pertenezcan al mismo tablespace. Cada segmento está formado por una o más extensiones. Extensiones.- El espacio se asigna a un segmento mediante extensiones. Una o más extensiones componen un segmento. Cuando se crea un segmento, éste está formado, como mínimo, por una extensión. A medida que el segmento va creciendo, se le agregan extensiones. El DBA puede agregar extensiones a un segmento manualmente. Una extensión es un juego de bloques Oracle contiguos. Una extensión no puede abarcar archivos de datos y, por tanto, debe existir en un archivo de datos.
41. ESTRUCTURA LOGICA Bloques de Datos.- Oracle Server gestiona el espacio de almacenamiento de los archivos de datos en unidades llamadas bloques Oracle o bloques de datos. Con el mayor nivel de granularidad posible, los datos de una base de datos Oracle se almacenan en bloques de datos. Los bloques de datos Oracle son las unidades de almacenamiento más pequeñas que Oracle Server puede asignar, leer o escribir. Un bloque de datos se corresponde con uno o más bloques del sistema operativo asignados desde un archivo de datos existente. El tamaño de bloque de datos estándar de cada base de datos Oracle lo especifica el parámetro de inicialización DB_BLOCK_SIZEcuando se crea la base de datos. El tamaño del bloque de datos debería ser múltiplo del tamaño del bloque del sistema operativo para evitar operaciones de E/S innecesarias. El tamaño máximo del bloque de datos depende del sistema operativo.