Anda di halaman 1dari 48

2 curso de administracin de sistemas informticos en red autor: Jorge Snchez www.jorgesanchez.

net

Para ver una copia completa de la licencia, acudir a la direccin http://creativecommons.org/licenses/by-nc-sa/2.5/es/legalcode.es

(5)

ndice
(1.1) repaso a la estructura de un SGBD ___________________________________________ 9
(1.1.1) Sistemas Gestores de Bases de Datos ................................................................................................................... 9 (1.1.2) niveles conceptuales. modelo ANSI/X3/SPARC ................................................................................................ 9 (1.1.3) funciones del SGBD .................................................................................................................................................10 (1.1.4) funciones avanzadas de un SGBD ....................................................................................................................... 11 (1.1.5) tareas del DBA ......................................................................................................................................................... 12

(1.2) Sistemas Gestores de Bases de Datos Comerciales ______________________________ 13


(1.2.1) licencias de software ............................................................................................................................................... 13 (1.2.2) SGBD relacionales de cdigo cerrado ............................................................................................................... 13 (1.2.3) SGBD relacionales de cdigo abierto ................................................................................................................ 14 (1.2.4) bases de datos NoSQL ........................................................................................................................................... 14

(1.3) opciones de funcionamiento de un SGBD _____________________________________ 15


(1.3.1) SGBD monocapa ..................................................................................................................................................... 15 (1.3.2) SGBD de dos capas ................................................................................................................................................. 15 (1.3.3) SGBD de tres o ms capas .................................................................................................................................... 16

(1.4) instalacin de SGBD ________________________________________________________ 16


(1.4.1) paso 1: seleccin por requisitos .............................................................................................................................. 16 (1.4.2) paso 2: comprobar requisitos ............................................................................................................................... 17

(1.5) instalacin de Access ________________________________________________________ 17 (1.6) Instalacin de MySQL _______________________________________________________ 17


(1.6.1) pasos previos ............................................................................................................................................................. 17 (1.6.2) documentacin ........................................................................................................................................................ 18 (1.6.3) instalacin en Windows ......................................................................................................................................... 18 (1.6.4) instalacin en Linux/Unix ..................................................................................................................................... 23 (1.6.5) asegurando la instalacin .................................................................................................................................... 28

(1.7) instalacin de Oracle _______________________________________________________ 29


(1.7.1) documentacin ........................................................................................................................................................ 29 (1.7.2) directorios de Oracle. comprender la estructura OFA ................................................................................ 29 (1.7.3) instalacin en Windows ......................................................................................................................................... 31 (1.7.4) instalacin en Linux ............................................................................................................................................... 33 (1.7.5) crear la base de datos ........................................................................................................................................... 35

(1.8) diccionario de datos ________________________________________________________ 42


(1.8.1) MySQL ........................................................................................................................................................................ 42 (1.8.2) Oracle ........................................................................................................................................................................ 43

(1.9) configuracin del sistema ___________________________________________________ 44


(1.9.1) configuracin de MySQL. Uso de opciones ...................................................................................................... 44 (1.9.2) configuracin de Oracle ....................................................................................................................................... 46

(1.10) archivos LOG _____________________________________________________________ 48


(1.10.1) ficheros LOG en MySQL....................................................................................................................................... 48 (1.10.2) ficheros LOG en Oracle ....................................................................................................................................... 48

(7)

Implantacin de aplicaciones web


ndice

(8)

(1) instalacin y configuracin de un Sistema Gestor de Bases de Datos


(1.1) repaso a la estructura de un SGBD
(1.1.1) Sistemas Gestores de Bases de Datos
Un Sistema Gestor de Base de Datos es el software que permite gestionar bases de datos, ocultando la fsica de la misma y permitiendo manejarla desde un nivel ms conceptual. Dicho software permite separar las aplicaciones (los programas) de los datos; de modo que los programas negocian con el SGBD el acceso a los datos. En definitiva se trata de un software complejo, pero de gran importancia por lo delicado de la rama de la informacin a la que se dedica. Los SGBD han crecido de manera exponencial estos ltimos aos por el xito de Internet, que ha creado la necesidad de que miles y miles de usuarios accedan a las mismas bases de datos de forma simultnea.

(1.1.2) niveles conceptuales. modelo ANSI/X3/SPARC


El grupo de trabajo SPARC de la seccin X3 de ANSI, diseo un modelo en el que indicaba cmo deba funcionar un SGBD para asegurar la separacin entre datos y aplicaciones y as especific tres niveles: Nivel externo. Define el nivel en el que los usuarios y usuarias utilizan la base de datos. La forma de ver la misma que no tiene nada que ver con la estructura real de la base de datos. Los usuarios manejan los esquemas externos de este nivel, pero dichos esquemas los realizan los desarrolladores/as de aplicaciones.

(9)

administracin de bases de datos


instalacin y configuracin de un Sistema Gestor de Bases de Datos

Nivel fsico. Se refiere a la forma en la que realmente se almacena la informacin de la base de datos. Los administradores (DBA) de la base de datos son los encargados de manejar este nivel Nivel conceptual. Define la base de datos haciendo referencia a la forma en la que se relaciona la informacin. Es un nivel ms humano que el fsico, pero no tanto como el externo: Hoy en da se definen ms niveles en realidad de modo que se habla de cinco niveles en realidad. Empezando desde el ms cercano al usuario: Nivel externo. Tal cual se explic antes. En realidad los esquemas de este nivel son los ltimos que se crean y lo hacen programadoras/es y analistas bajo la direccin de las/os analistas. Nivel conceptual. Con la misma idea indicada anteriormente. En realidad el esquema (los planos) conceptual de la base de datos es lo primero que se disea por los o las analistas o diseadores de la misma utilizando un modelo para realizar los esquemas. El modelo Entidad/Relacin sigue siendo el modelo ms popular. Nivel lgico. Acerca ms el esquema anterior a la fsica de la base de datos. En este nivel se hace referencia a estructuras lgicas del tipo de SGBD a manejar (tablas, filas, columnas por ejemplo en el modelo relacional de bases de datos, el modelo lgico ms utilizado). Este nivel sigue siendo manejado por los analistas. En muchos casos (aunque ciertamente es criticable) los diseadores/as de la base de datos empiezan por este nivel saltndose el anterior. Nivel interno. Es el primero en el proceso de modelado de la base de datos que se realiza sobre la base de datos (teniendo en cuenta que lo externo, las aplicaciones, se crean ms tarde). Usa el lenguaje de la base de datos para crear las estructuras de datos definidas en el nivel lgico. Este nivel lo maneja el administrador de la base de datos. Nivel fsico. Se refiere a como se organizarn los datos en el disco, en que ordenadores se crea la base de datos, si es distribuida o no, sistema operativo necesario, estructura de directorios y archivos, poltica de copia de seguridad, La persona encargada de definir todo esto es la administradora de la base de datos o, mejor, la administradora del sistema. En realidad hay acciones referidas a este nivel que se hacen antes que las del nivel anterior; otras se irn haciendo despus o a la vez.

(1.1.3) funciones del SGBD


El manejo de la SGBD implica que nos permita realizar estas funciones: Funcin de descripcin o definicin. Permite al diseador de la base de datos crear las estructuras apropiadas para integrar adecuadamente los datos. Esta funcin se realiza mediante el lenguaje de descripcin de datos o DDL. Mediante ese lenguaje: Se definen las estructuras de datos (los metadatos) Se definen las relaciones entre ellas Se definen las reglas que han de cumplir (10)

2 curso de administracin de sistemas informticos en red autor: Jorge Snchez www.jorgesanchez.net

Funcin de manipulacin. Permite modificar y utilizar los datos de la base de datos. Se realiza mediante el lenguaje de modificacin de datos o DML. Mediante ese lenguaje se puede: Aadir datos Eliminar datos Modificar datos

Buscar datos Actualmente se suele distinguir aparte la funcin de buscar datos en la base de datos (funcin de consulta). Para lo cual se proporciona un lenguaje de consulta de datos o DQL. Tambin las transacciones (que usan lenguaje DTL) se consideran parte de esta funcin. Funcin de control. Mediante esta funcin los administradores poseen mecanismos para proteger las visiones de los datos permitidas a cada usuario, adems de proporcionar elementos de creacin y modificacin de esos usuarios. El lenguaje que implementa esta funcin es el lenguaje de control de datos o DCL.

(1.1.4) funciones avanzadas de un SGBD


Para poder garantizar que una SGBD cumple las funciones anteriores de la mejor forma posible y adems seguir garantizando la independencia entre los tres esquemas fundamentales (externo, conceptual y fsico) y adems facilitar su manejo, los SGBD tienen que cumplir de forma estricta una serie de reglas. Edgar F. Codd (que teoriz el modelo relacional de la base de datos) escribi 12 reglas que haban de cumplir todos los SGBD. Hoy en da casi todas las grandes bases de datos son relacionales y los SGBD se afanan en cumplir esas reglas. Por lo que entre sus funciones es normal considerar las siguientes: Un catlogo de datos. Tambin llamado esquema de informacin o diccionario de datos. En l se recogen todos los metadatos, as como la relacin que tienen entre s. Por ejemplo: tipos de datos, usuarios y privilegios, tablas, restricciones de los datos, nombre y estructura de las vistas, Posibilidad de establecer reglas de integridad avanzadas e incluirlas como parte de la base de datos. Especialmente complicado suele ser poder establecer las reglas de integridad referencial (foreign key), por lo que algunos SGBD no lo incluyen. Gestin de copias de seguridad. Una de las funciones crticas de la base de datos. Aplicaciones de exportacin e importacin de datos. Para poder utilizar datos de otros SGBD u otro software. Posibilidad de recuperacin en caso de desastre. Para evitar perder informacin en caso de problemas serios con el software (errores de hardware, apagones prolongados,) Archivos LOG. Desde los que podemos examinar las incidencias y monitorizar el funcionamiento de la base de datos. Herramientas para programar aplicaciones. aplicaciones (o facilidades) de usuario. (11) Que permitan crear las

administracin de bases de datos


instalacin y configuracin de un Sistema Gestor de Bases de Datos

Gestin de la comunicacin con los clientes de la base de datos. Permiten establecer conexin con la base de datos desde mquinas remotas. Optimizacin de consultas. Busca el mnimo tiempo de respuesta para las operaciones sobre los datos. Automatizar tareas. Permiten programar operaciones sobre la base de datos. Uso de herramientas grficas. Para facilitar todas las tareas de la base de datos. Posibilidad de distribuir la base de datos entre diferentes mquinas, y as mejorar su disponibilidad.

(1.1.5) tareas del DBA


Un administrador de bases de datos (DBA), tiene una serie de tareas asignadas. Todas ellas son de vital importancia para la base de datos; algunas son especialmente crticas. Las tareas ms comnmente aceptadas como parte de la profesin del DBA son:

(1)

Configurar e instalar el hardware necesario. Para el correcto funcionamiento del SGBD. Eso incluye ampliar memoria, discos duros, adems de configurarles para su ptimo rendimiento. Tambin la gestin mnima del sistema operativo para que la base de datos funcione correctamente. Instalacin en s del SGBD. Seleccionando la ms adecuada forma de instalacin y configurando lo necesario para su ptimo rendimiento acorde con las necesidades. Crear la estructura fsica de la base de datos. Tarea fundamental y quiz la ms relacionada habitualmente con un DBA. Control de los usuarios y los permisos. En definitiva establecer las polticas de seguridad tan imprescindibles en toda base de datos. Monitorizar y optimizar el rendimiento de la base de datos. Un DBA debe detectar los cuellos de botella del sistema y actuar en consecuencia. Realizar tareas de copia de seguridad y recuperacin. Quiz la tarea ms crtica. Consiste en realizar acciones para en caso de catstrofe poder recuperar todos los datos

(2)

(3) (4) (5) (6)

(12)

2 curso de administracin de sistemas informticos en red autor: Jorge Snchez www.jorgesanchez.net

(1.2) Sistemas Gestores de Bases de Datos Comerciales


(1.2.1) licencias de software
El gur del software libre, Richard Stallman considera al software propietario (propiedad de una empresa que oculta su cdigo fuente), software privativo, puesto que ocultar el cdigo no permite modificar el mismo y adaptarlo a nuevas funcionalidades. As el mismo define al software que s permite este proceso, software libre. En cualquier caso ambos tipos de software no tienen por qu ser gratuitos, es decir la diferencia no es la gratuidad (aunque s ocurre a menudo que el software de cdigo abierto adems suele ser gratuito). Una definicin quiz menos tendenciosa es software de cdigo abierto y de cdigo cerrado. Est diferencia de software se debe a dos formas diferentes de hacer negocio con l; los defensores del cdigo cerrado argumentan que es lgico protegerle para evitar copiar su tecnologa y por razones de seguridad del mismo al no poder asegurar su funcionamiento ante modificaciones de terceros. Los defensores del segundo modelo estn a favor de la versatilidad que imprime poder modificar el cdigo y que el software mejora mucho ms ante las modificaciones de legiones de programadores de todo el mundo.

(1.2.2) SGBD relacionales de cdigo cerrado


Normalmente las licencias de uso de Sistemas Gestores de Bases de Datos con cdigo cerrado usan licencias tipo CLUF o EULA (en ingls), acrnimo contrato de licencia de usuario final. En el que el usuario firma unas condiciones de uso por el software, entre las que siempre figuran el hecho de no poder distribuir el mismo y que est restringido a unas condiciones de trabajo concretas. Ejemplos de SGBD de este tipo son: Oracle. Propiedad de Oracle Corporation. Es el SGBD ms veterano y ms influyente ya que la mayora de mejoras al SQL original se desarrollaron para este SGBD. Sigue siendo uno de los SGBD comerciales ms utilizados y adems posee una gran relacin con el lenguaje Java, acrecentada por la compra de la empresa creadora del mismo, Sun Microsystems. Presume de su gran estabilidad y escalabilidad, un control avanzado de transacciones y de sus lenguajes internos de manejo, especialmente famoso es su lenguaje procedimental PL/SQL. Es un SGBD multiplataforma, que tiene certificacin para instalarse en Linux. DB2. Propiedad de IBM, es una de las bases de datos comerciales ms populares. Desarrollada para Windows, UNIX y Linux. Implementa XML de manera nativa y dispone de amplias facilidades de migracin de datos (especialmente desde Oracle) as como uso de transacciones avanzadas. SQL Server (de Microsoft). Originalmente basado en el cdigo del SGBD SyBase que Microsoft compr al propietario de SyBase, ahora es un SGBD distinto distribuido slo para Windows y que compite con los dos anteriores. Dispone de una gran escalabilidad, estabilidad, uso de transacciones, entorno grfico (13)

administracin de bases de datos


instalacin y configuracin de un Sistema Gestor de Bases de Datos

avanzado y de xito entre los programadores de la plataforma .NET (tambin de Microsoft por su compatibilidad con esta). Las tres son de las bases de datos ms utilizadas en la actualidad por su contrastada potencia. Ninguna de las tres cumple completamente los estndares y aportan sus propios lenguajes y forma de trabajo. Adems las tres disponen de versiones gratuitas para uso personal con base de datos ms pequeas.

(1.2.3) SGBD relacionales de cdigo abierto


Algunas utilizan la licencia GNU GPL (GNU General Public License), que utilizan por ejemplo los sistemas Linux y que permite modificar el cdigo, redistribuirlo; pero manteniendo la licencia. Otra licencia muy utilizada de cdigo abierto es la que utiliza el sistema operativo BSD, que incluso permite redistribuir el software cerrando el cdigo. Los SGBD ms conocidos de cdigo abierto son: MySQL. Inicialmente creada por la empresa MySQL AB, posteriormente comprada por Sun Microsystems que, a su vez, fue comprada por Oracle. Ha sido considerada como la principal SGBD de la comunidad de programadores de cdigo abierto y de hecho en Internet sigue siendo la principal base de datos asociada a una aplicacin web. Mantiene su licencia de tipo GPL, pero posee una segunda licencia cerrada para opciones ms avanzadas. Es muy popular por su histrica asociacin con PHP, por su buena estabilidad, gran escalabilidad, e incluso uso de transacciones y lenguaje procedimental; adems de ser un producto con infinidad de plataformas posibles para su instalacin. PostgreSQL. Versin de cdigo abierto basada en el producto Ingres de la Universidad de Berkeley. Usa licencia de tipo MIT (del Instituto Tecnolgico de Machassuchets) que es una de las ms libres, permite su modificacin, redistribucin incluso hacia otro tipo de licencias del tipo que sean, sin usar en ningn momento copyright. Est considerado como el SGBD de cdigo abierto ms potente y, sobre todo, ms fidedigno con los estndares. Posee uso de transacciones avanzadas, lenguaje procedimental, gran estabilidad y escalabilidad, Firebird. Se trata de un SGBD liberado del SGBD Interbase que era propiedad de Borland y que fue liberado con una variante de la licencia que usa Mozilla (MPL) que, a su vez, se basa en la licencia BSD. Tiene soporte transacional avanzado, buena estabilidad pero no es muy escalable. Apache Derby. Anteriormente, IBM Cloudscape, usa licencia Apache que es poco restrictiva con las redistribuciones. Est programa en Java y pensada para ser utilizada en ese mismo lenguaje.

(1.2.4) bases de datos NoSQL


Se trata de un trmino que actualmente se ha puesto muy en uso para designar a las bases de datos que no utilizan, o no cumplen del todo, las bases del estndar SQL. Especialmente se usa este trmino para designar a las bases de datos que no utilizan esquemas relacionales estrictos y que especialmente evitan la instruccin JOIN. Aunque se utiliza para designar a las bases de datos documentales, grficas y otros esquemas de bases de datos; actualmente se utiliza especialmente para designar a las (14)

2 curso de administracin de sistemas informticos en red autor: Jorge Snchez www.jorgesanchez.net

bases de datos que requieren tantas transacciones por segundo, que el esquema relacional tradicional no dara abasto para ello. Por esto utilizan un modelo diferente en el que los datos se almacenan de forma menos estricta, en especial no siguen las reglas ACID de transacciones, como s hacen los SGBD potentes relacionales (como Oracle, DB2, SQLServer o PostgreSQL). ACID hace referencia a las propiedades atomicidad, consistencia, aislamiento y durabilidad de las bases de datos. Cumplir esas propiedades de forma estricta no permite que sitios como web puedan atender con garantas a todas sus peticiones por el tiempo necesario para actualizar los ndices, por lo que necesitan otro esquema ms rpido (aunque sea un poco menos consistente). La clave de este tipo de bases de datos es su capacidad para ser sistemas muy distribuidos y ultrarrpidos al almacenar datos. Su desventaja es el tiempo que requeriran al realizar otro tipo de tareas como ordenar los datos en base a distintas claves o en realizar bsquedas avanzadas. Triunfan donde ese tipo de tareas de gestin no son crticos (como las redes sociales, donde las cosas slo se suelen ordenar en base a la fecha y hora). Algunos SGBD de ese tipo son: Apache Cassandra. Con licencia Apache, es la ms popular y de contrastada potencia. La usa Facebook, twitter, Digg, Cisco WebEx. Amazon Dynamo. Basado en la anterior es la utilizada y desarrollada por la empresa Amazon. Google BigTable. Base de datos propietaria utilizada para muchos de los servicios de almacenamiento de Google. Azure Tables. Uno de los sistemas de almacenamiento de la plataforma Windows Azure de Microsoft, creada para implementar su computacin en la nube.

(1.3) opciones de funcionamiento de un SGBD


(1.3.1) SGBD monocapa
Se trata de Sistemas Gestores instalados en una mquina desde la que se conectan los propios usuarios y administradores. Es un modelo que solo se utiliza con bases de datos pequeas y poca cantidad de conexiones.

(1.3.2) SGBD de dos capas


Es el modelo tipo cliente/servidor. La base de datos y el sistema gestor se alojan en un servidor al cual se conectan los usuarios desde mquinas clientes. Un software de comunicaciones se encarga de permitir el acceso a travs de la red. Los clientes deben instalar el software cliente de acceso segn las instrucciones de configuracin del administrador. Hay dos posibilidades: Arquitectura cliente/servidor nico. Un solo servidor gestiona la base de datos, todos los clientes se conectan a l pare realizar las peticiones a la base de datos. Arquitectura cliente/multiservidor. La base de datos se distribuye entre varios servidores. El cliente no sabe realmente a que servidor se conecta, el software (15)

administracin de bases de datos


instalacin y configuracin de un Sistema Gestor de Bases de Datos

de control de comunicaciones se encargar de dirigirle al servidor adecuado. De forma lgica, es como si se tratara de un solo servidor aunque fsicamente sean muchos.

(1.3.3) SGBD de tres o ms capas


En este caso entre el cliente y el servidor hay al menos una capa intermedia (puede haber varias). Esa capa (o capas) se encargan de recoger las peticiones de los clientes y luego de comunicarse con el servidor (o servidores) para recibir la respuesta y enviarla al cliente. El caso tpico es que la capa intermedia sea un servidor web, que recibe las peticiones a travs de pginas web; de este modo para conectarse a la base de datos, el usuario solo requiere un navegador web, que es un software muy habitual en cualquier mquina. Este modelo es el que ms se est potenciando en la actualidad por motivos de seguridad y portabilidad de la base de datos.

(1.4) instalacin de SGBD


A la hora de instalar el Sistema Gestor de la Base de Datos necesitamos primero hacer un planteamiento de necesidades a fin de encontrar el ms apropiado para resolver el problema.

(1.4.1) paso 1: seleccin por requisitos


Se trata de analizar qu necesitamos del SGBD. En este sentido algunas cosas a tener en cuenta pueden ser: Tamao de la base de datos. Un gran tamao de base de datos requiere se software muy potente para la gestin de la misma, adems podra plantear el hecho de separar los datos en distintas unidades de disco o incluso mquinas lo que podra requerir clsteres o sistemas distribuidos. Conectividad. Si necesitamos que la base de datos sea accesible desde Internet, una Intranet o incluso si bastara con un solo equipo de acceso. Nmero de usuarios. Un nmero grande de usuarios requiere controles avanzados de seguridad. Nmero de conexiones simultneas. Suele ser el punto lgido de requisitos, ya que un gran nmero de conexiones simultneas implica SGBD con grandes capacidades de trabajo concurrente y pocos Sistemas seran capaces de aceptarlo. Aprovechamiento de hardware. Puede ser que sea el propio hardware de la empresa el que predetermine la seleccin al estar limitados por el mismo. Poltica de empresa. Por ejemplo si la empresa tiene una poltica de impulso

(16)

2 curso de administracin de sistemas informticos en red autor: Jorge Snchez www.jorgesanchez.net

de software libre o acuerdos con empresas concretas de software.

(1.4.2) paso 2: comprobar requisitos


Una vez seleccionado el SGBD ahora tenemos que asegurarnos de cumplir nosotros los requisitos que exige. Todos los sistemas indican qu requisitos necesitan en cuanto a: Sistemas operativos. No todos los SGBD son multiplataforma, lo normal es que sean compatibles con unas cuantas plataformas: Windows, Linux, Unix, Paquetes o aplicaciones preinstaladas. A veces se requiere que el sistema posea algn software previo a la instalacin del SGBD. En el mundo Linux se suele requerir de paquetes (como por ejemplo el compilador de C, o libreras especiales de entrada salida,); en Windows es alguna actualizacin (como sus clsicos Service Pack) o software previo (como la mquina Java, o el Framework .Net). Memoria RAM. Es el requisito que ms importa: ms RAM, ms ligero funciona el sistema Procesador. Se suele exigir una velocidad mnima en el mismo. Disco duro. Se exige un espacio mnimo de disco. Requisitos de red. Se puede exigir que el equipo tenga una funcin concreta como que sea un servidor de dominio, o que tenga una conectividad particular (como una direccin IP fija). Incompatibilidades. A veces se indican productos con los que existen problemas de compatibilidad.

(1.5) instalacin de Access


Access es un sistema monocapa muy popular al ser parte de la exitosa suite ofimtica Microsoft Office. Su instalacin es sencilla. Una vez instalada, toda la configuracin se realiza desde un entorno grfico en el que se configura toda la administracin as como las tareas de gestin, mantenimiento y manipulacin de datos.

(1.6) Instalacin de MySQL


(1.6.1) pasos previos
Antes de instalar MySQL (al igual que otro software cuya instalacin sea crtica) se deben tomar estas decisiones: Comprobar hardware mnimo necesario Decidir la distribucin. MySQL est disponible para numerosas plataformas, hay que decidir para cul nos interesa, en base al precio del sistema, fiabilidad, buena integracin, etc.

(17)

administracin de bases de datos


instalacin y configuracin de un Sistema Gestor de Bases de Datos

Decidir el formato de la distribucin. Hay dos posibilidades: Distribucin binaria. Se trata de una forma ms fcil y rpida de instalar. Puede ser a travs de un instalador preparado o bien a travs de binarios genricos comprimidos. En el ltimo caso, simplemente con descomprimir y realizar unos cuantos ajustes, tenemos la instalacin finalizada Cdigo fuente. Se trata de que debemos compilar el cdigo fuente para que funcione el SGBD. Es ms complicada de realizar pero permite un mayor control de todos los componentes a instalar, as como preparar un ejecutable ptimo para nuestro sistema o bien incluso modificar el cdigo (que es C y C++).

Obtener los archivos. De la direccin: http://dev.mysql.com/downloads.

(1.6.2) documentacin
MySQL dispone de manuales tanto en lnea como descargables (por ejemplo en formato PDF) a travs de la pgina http://dev.mysql.com/doc/

(1.6.3) instalacin en Windows


Es la versin ms descargada de MySQL. Hay dos opciones: Distribucin binaria, que permite iniciar el servidor inmediatamente. Es un archivo msi, con las ventajas que eso tiene en un entorno de trabajo Windows. Opciones: Instalador msi Instalacin comprimida en formato ZIP

Distribucin de cdigo fuente para ser compilada con el compilador VC++ 6.0.

instalacin con un paquete msi


instalacin con el asistente El asistente de MySQL es el programa que permite facilitar la instalacin del software. Los pasos a realizar con l son:

(1) (2) (3)

Aceptar el cuadro con la informacin inicial Escoger el tipo de instalacin. La opcin personalizada (Custom) permite elegir ms a fondo los componentes a instalar. Confirmar la instalacin

Tras finalizar estos pasos, automticamente se modifica el registro de Windows, se aade un grupo para MySQL en el men de Inicio y una carpeta (por ejemplo MySQL 5.5) dentro de la carpeta de los programas en el sistema de archivos de Windows (por ejemplo con la ruta C:\Program Files\MySQL\MySQl 5.5).

(18)

2 curso de administracin de sistemas informticos en red autor: Jorge Snchez www.jorgesanchez.net

instalar la instancia de MySQL El sistema MySQL en s funcionar en cuanto lancemos el asistente para gestionar la instancia. La instancia es el proceso de base de datos que permite el acceso a la base de datos. Eso puede hacerse en el ltimo paso del asistente anterior o bien lanzando el programa en la carpeta bin del directorio de MySQL, MySQLInstanceConfig. Una vez lanzado la primera pantalla es esta:

Ilustracin 1, Imagen inicial del asistente de configuracin de la instancia del servidor MySQL

Con l los pasos a realizar son: Elegir el tipo de instalacin. La detallada permite ms opciones de configuracin. Elegir el tipo de servidor que deseamos: Developer Machine. Mquina de Desarrollo. Para uso personal solamente, consumir una cantidad mnima de recursos. Server machine. Servidor. Se entiende que comparte espacio con otros servidores (web, de correo, ftp). Consume una cantidad moderada de recursos. Dedicated Machine. Servidor dedicado. Se elige si slo se utiliza como servidor a MySQL.

Uso de la base de datos. En realidad gestiona qu motores de la base de datos se usarn. MySQL dispone de dos opciones InnoDB (con buena capacidad de manejo de transacciones, pero ms lenta en aadir datos) y MyISAM, ms rpida pero con menos control de la integridad de los datos. Las opciones del cuadro son: Multifuncional. Instala ambos motores y les da la misma potencia. Transacional. Instala ambos, pero da preferencia a InnoDB en los recursos a fin de manejar correctamente las transacciones. (19)

administracin de bases de datos


instalacin y configuracin de un Sistema Gestor de Bases de Datos

No transacional. Desactiva InnoDB y activa sola MyISAM.

Eleccin del directorio donde instalar los datos. Lo que se conoce como la ubicacin del tablespace de datos. Slo se usa con InnoDB y permite colocar los datos en otra ubicacin respecto a los del programa MySQL o incluso en otra unidad de disco. Eleccin del nmero de conexiones concurrentes. La primera opcin es para bases de datos con escaso nmero de conexiones concurrentes, la segunda pensada para transacciones en lnea (OLTP) y la tercera permite editar a mano el nmero de conexiones concurrentes. Seleccin del nmero de puerto (normalmente el 3306) y elegir si deseamos el modo estricto de trabajo (es lo recomendable). Eleccin del juego de caracteres que se utilizar para codificar el texto de la base de datos. Eleccin del modo de trabajo del servicio. Normalmente MySQL se instala como un servicio de Windows ms, pero podramos no desearlo. Se puede cambiar el nombre al servicio. En este mismo paso se puede modificar el PATH de Windows para incluir el directorio bin en el path y as desde la lnea de comandos utilizar los comandos mysql sin tener que modificar nuestra ruta. El siguiente paso es muy importante. Se DEBE de cambiar la contrasea del usuario root, del superadministrador, por seguridad. Adems se puede elegir si permitimos los accesos de este usuario de forma remota (desde otro ordenador) y si activamos la cuenta annima (acceso sin contrasea), que no es recomendable. Tras esos pasos comienza la instalacin en s. Si todo va bien aparece un mensaje como ste:

Ilustracin 2, Cuadro de dilogo que aparece cuando la instalacin ha concluido

En el cuadro ltimo, se indica la ruta del archivo de configuracin en el que se han guardado los parmetros de instalacin. Es el archivo my.ini situado en la carpeta de instalacin de MySQL. Examinar ese archivo es interesante y modificarle permitira cambiar el funcionamiento de MySQL independientemente de lo que se haya especificado en la instalacin. (20)

2 curso de administracin de sistemas informticos en red autor: Jorge Snchez www.jorgesanchez.net

comprobar funcionamiento de MySQL Necesitamos probar la instalacin. En Windows, MySQL crea las tablas de privilegios y usuarios sin tener que configurar ms. Adems crear tres bases de datos y diversas tablas en ellas como ejemplo. MySQL ser un servicio que se iniciar automticamente en el arranque. De no desearlo as debemos ir a la pantalla de Servicios de Windows (dentro de la carpeta de herramientas administrativas) y parar el servicio adems de indicar que no deseamos su inicio automtico (en las propiedades del servicio MySQL). Para detener el servicio, basta ir a la lnea de comandos e indicar el comando: net stop MySQL Si deseamos iniciar de nuevo el servicio: net start MySQL Si el servicio est funcionando, para probar el funcionamiento basta con conectar con MySQL desde la lnea de comandos, por ejemplo con: mysql u root p Despus se nos solicitar la contrasea del administrador. Y entonces estaremos viendo el Shell de MySQL (la pantalla que interpreta comandos MySQL). Por ejemplo ejecutando el comando show databases, se nos mostrarn las bases de datos ejemplo de MySQL. En el caso de que el servidor no arranque con el comando net, podemos lanzar MySQL invocando al programa (demonio) mysqld desinstalar MySQL en el caso de instalacin con el paquete msi Para ello basta con ir al panel de control, localizar MySQL y desinstalar. Pero eso elimina slo los archivos de MySQL que se crearon en la instalacin, los archivos de configuracin y datos permanecern donde se crearon y eso puede causar problemas en otra instalacin. Para desinstalar completamente:

(1) (2)

Desinstalar desde el panel de control Eliminar el contenido de C:\Documents and Settings\All Users\Application Data\MySQL, o bien en Windows 7 o Windows Server 2008 C:\ProgramData\MySQL (ProgramData es una carpeta oculta que deberemos mostrar con la opcin de mostrar carpetas y archivos ocultos de Windows) Revisar la carpeta de instalacin de MySQL y comprobar que no ha quedado ningn archivo sin borrar

(3)

(21)

administracin de bases de datos


instalacin y configuracin de un Sistema Gestor de Bases de Datos

instalar MySQL desde un fichero ZIP


En ese caso tenemos un archivo comprimido que contiene la instalacin de MySQL, simplemente habr que configurar la instalacin. Los pasos son:

(1) (2)

Extraer el fichero ZIP en la ubicacin deseada Crear un fichero de opciones con al menos las lneas donde colocar la ubicacin de MySQL y los datos. Aunque hay varias posibilidades de colocar el archivo de configuracin (como se describir ms adelante), lo habitual es llamarle my.ini y colocarle en la carpeta de instalacin de Windows (por ejemplo C:\Windows). Conviene copiar uno de los archivos de configuracin que se encuentran en la carpeta raz de MySQL (por ejemplo my-medium.ini), cambiarle el nombre a my.ini y modificar las lneas deseadas. Ejemplo de ello es por ejemplo indicar cul es el directorio raz de MySQL y la carpeta donde se almacenar la base de datos. Para ello se aadiran las siguientes lneas a la seccin mysqld: [mysqld] .. otros parmetros de configuracin # coloca en basedir el directorio de instalacin basedir=E:/mysql # coloca en datadir el directorio de datos datadir=E:/mydata/data Como se ve en el ejemplo MySQL usa las barras de los directorios al estilo Unix (/ en lugar de \). Para que la ruta cuadre con el archivo de opciones es necesario asegurar que la raz de los archivos de MySQL se encuentra donde se ha marcado en el archivo de opciones. Nota: Normalmente el directorio de datos (data), se encuentra debajo de la raz de instalacin de MySQL, si deseamos utilizar la nueva ubicacin deberemos copiar el contenido de data a esa nueva ubicacin.

(3) (4)

Colocar la ruta al directorio bin de MySQL dentro de la variable PATH de Windows. Lanzar la instancia de la base de datos desde la lnea de comandos escribiendo: mysqld --console. Tras este comando (si la configuracin est bien), se quedar la consola con el mensaje: Version: '5.5.16' socket: '' port: 3306 MySQL Community Server (GPL) (suponiendo que disponemos de MySQL Community Server versin 5.5.16). El servidor MySQL est lanzado y escuchando por el puerto 3306

(5)

Para el resto de veces bastar con lanzar el demonio de MySQL (mysqld), simplemente escribiendo mysqld en la lnea de comandos.

arrancar MySQL como un servicio Tambin es posible en este tipo de instalacin arrancar MySQL como un servicio. Basta con: mysqld --install

(22)

2 curso de administracin de sistemas informticos en red autor: Jorge Snchez www.jorgesanchez.net

Si no funcionara es posible que el servidor MySQL est en funcionamiento. Detener implica usar el comando: mysqladmin -u root shutdown Desde este instante tendremos MySQL colocado como servicio de Windows. Disponemos de las opciones de comandos: mysql --install-manual. Para instalar MySQL como servicio que debe iniciarse manualmente. mysql --remove. Para eliminar MySQL como servicio. desinstalar si la instalacin es desde un ZIP

(1) (2) (3) (4)

Desinstalar el servicio de MySQL si es tal. En todo caso detener la instancia definitivamente de MySQL con sc delete mysql Si lo anterior no funciona (por ejemplo sino se configur como servicio), entonces: mysqladmin -u root shutdown Borrar el archivo de configuracin my.ini Borrar los archivos de MySQL

En realidad en este tipo de instalacin, todo es ms sencillo porque no se instala MySQL al estilo de las aplicaciones de Windows El usuario administrador en este tipo de instalacin no posee contrasea; habra que cambiarla ms tarde.

(1.6.4) instalacin en Linux/Unix


instalacin binaria genrica
La instalacin binaria genrica en los sistemas de tipo Unix es similar a la de Windows mediante archivo ZIP. Este tipo de instalacin valdra para cualquier versin de Linux. La ventaja es la comodidad y el hecho de que se maneje igual en todo tipo de Unix/Linux. La desventaja es que esta instalacin no est optimizada para la versin de Linux concreta en la que instalamos MySQL. La instalacin crear una carpeta raz desde la que colgarn todos los directorios de MySQL, concretamente: directorio bin data docs man include lib scripts share sql-bench uso Ubicacin de los programas MySQL Ubicacin de los datos de las bases de datos Manual en formato info de Linux Manual en formato del comando man de Unix Cabeceras de cdigo fuente Archivos de librera Contiene el script mysql_install_db Mensajes de error, juegos de caracteres, ejemplos, Benchmarks (23)

administracin de bases de datos


instalacin y configuracin de un Sistema Gestor de Bases de Datos

Los pasos son:

(1)

Descargar el archivo comprimido con la instalacin desde http://dev.mysql.com/downloads/ Ser algo as como Linux Generix xxxx.tar.gz TAR Compressed donde las equis indican la versin del sistema (por ejemplo versin 2.6 de 32 o 64 bits) Abrir la consola de comandos (el Shell) con privilegios administrativos y ejecutar la orden: groupadd mysql. Esto aade un grupo para el usuario relacionado con MySQL Ejecutar la orden: user add -g mysql mysql. Esto crea un usuario llamado mysql que pertenece al grupo anterior. Colocarnos en el directorio que contendr la instalacin de MySQL. Lo habitual es el comando: cd /usr/local. Descomprimir el archivo con: tar zxvf rutaCompletaAlArchivoTAR.tar.gz. Necesitamos indicar la ruta al archivo tar para descomprimirlo en la carpeta en la que nos posicionamos en el punto 4. Es decir si hemos descargado MySQL en la carpeta de descargas, podra ser: tar zxvf $HOME/Downloads/MySQL-5.5.161.Linux.2.6.x86_64.tar.gz. El resultado es MySQL descomprimido en /usr/local (o en el directorio que hayamos indicado en el punto 4.

(2)

(3)

(4) (5)

(6) (7)

Modificar el nombre del directorio, para que sea ms entendible. Por ejemplo: mv /usr/local/mysql-5.5.16-linux.2.6-x86_64 /usr/local/mysql Ir al directorio raz de MySQL (con cd /usr/local/mysql usando el nombre creado en el punto anterior) desde ah dar propiedad de los archivos de MySQL al usuario root y grupo mysql creados anteriormente. Al usuario mysql se le da la propiedad de la carpeta data donde se encuentran los datos: chown -R root . chown mysql data chgrp -R mysql . Para el paso siguiente necesitamos la librera libaio1, si no disponemos de ella hay que instalarla. En los Linux tipo Debian (como Ubuntu) con: apt-get install libaio1 libaio-dev En los Linux tipo Red Hat (como Fedora) con: yum install libaio1

(8)

(9)

Instalar las tablas iniciales mediante (suponiendo que seguimos en la raz de MySQL): scripts/mysql_install_db --user=mysql Iniciar MySQL, pero teniendo cuidado de hacerlo sin ser el usuario root. La forma de hacerlo (situados desde la raz de MySQL): bin/mysqld_safe --user=mysql & (24)

(10)

2 curso de administracin de sistemas informticos en red autor: Jorge Snchez www.jorgesanchez.net

Si sale bien el servidor estar funcionando correctamente. En la pantalla de consola, no aparece el prompt del sistema ya que se queda esperando la finalizacin del proceso lanzado; algo que no ocurrir hasta que nosotros le paremos.

(11)

Comprobar que realmente MySQL est funcionando con (situados desde la raz de MySQL): bin/mysqladmin version Si todo ha ido bien, el resultado sera algo como: bin/mysqladmin Ver 8.42 Distrib 5.5.16, for linux2.6 on x86_64 Copyright (c) 2000, 2011, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners. Server version Protocol version 10 Connection UNIX socket Uptime: 5.5.16 Localhost via UNIX socket /tmp/mysql.sock 1 min 27 sec

Threads: 1 Questions: 1 Slow queries: 0 Opens: 33 Flush tables: 1 Open tables: 26 Queries per second avg: 0.011

(12)

Comprobar que podemos cortar MySQL (situados desde la raz de MySQL): bin/mysqladmin -u root shutdown Si volvemos a comprobar si MySQL est en pie mediante el comando mysqladmin versin, debera salir algo parecido a: bin/mysqladmin: connect to server at 'localhost' failed error: 'Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)' Check that mysqld is running and that the socket: '/tmp/mysql.sock' exists!

(13) (14)

Lanzar de nuevo el servidor (situados desde la raz de MySQL): bin/mysqld_safe --user=mysql Entrar en MySQL (situados desde la raz de MySQL): bin/mysql

No hay contraseas para ningn usuario, por lo que es conveniente hacerlo (se explica ms adelante

(25)

administracin de bases de datos


instalacin y configuracin de un Sistema Gestor de Bases de Datos

preparar MySQL para el inicio automtico Si se desea que MySQL se inicie automticamente en cada encendido del ordenador, bastar con copiar el script mysql.server que se encuentra en el directorio supportfiles que, a su vez, est en la raz de MySQL. La copia se realiza al directorio que contiene los scripts de inicio del sistema, normalmente /etc/init.d El comando a ejecutar sera (estando en la raz de MySQL): cp support-files/mysql.server /etc/init.d/mysqld chmod +x /etc/init.d/mysqld Eso le coloca en los scripts de inicio con el nombre mysql y le da permiso de ejecucin. Desde ese momento el servicio mysql ya existe. Y es posible lanzar y parar mysql con los comandos: service mysqld start y para detener: service mysqld stop Para lanzar automticamente en cada reinicio existen comandos en los diversos Linux. El ms popular: chkconfig --level 345 mysqld on Que iniciar el servidor en los niveles 3,4 y 5 del sistema, con el cdigo de secuencia 50. En el caso de Ubuntu (y de otros Linux tipo Debian), ese comando no existe y actualmente se puede utilizar: update-rc.d mysqld defaults que coloca el servicio mysql en los niveles 2,3,4 y 5 y le asigna el cdigo de secuencia 20. Este otro comando es equivalente al chkconfig anterior: update-rc.d mysqld start 50 2 3 4 5 . stop 50 0 1 6 Ambos comandos tienen ms opciones que sern fciles de utilizar para quienes tengan conocimientos sobre cmo funciona el arranque en Linux. Para que estas opciones funciones, el archivo de configuracin my.cnf, situado normalmente en /etc/my.cnf debera contener estas lneas al menos (suponiendo que mysql se ha instalado en la ruta /usr/local/mysql): [mysqld] . datadir=/usr/local/mysql/data [mysql.server] basedir=/usr/local/mysql La ruta /usr/local/mysql en el ejemplo es la que apunta a la raz de MySQL.

(26)

2 curso de administracin de sistemas informticos en red autor: Jorge Snchez www.jorgesanchez.net

desinstalar MySQL si la instalacin es binaria ZIP Si deseamos desinstalar MySQL del sistema; en este caso basta con parar el servidor, eliminar los servicios relacionados con MySQL (si es necesario) que se inician con el sistema y eliminar la carpeta raz y todos los subdirectorios (comando rm -R)

instalacin mediante gestores de paquetes


Casi todos los Linux tienen predefinidos paquetes para instalar MySQL. Es el caso de los paquetes rpm que se pueden instalar fcilmente en cualquier Linux de tipo Red Hat (como Fedora). Es la instalacin recomendada desde el fabricante, la cuestin es que la localizacin de los programas vara respecto a la instalacin mediante binarios genricos. Por paquetes MySQL se organiza de la siguiente manera: directorio /usr/bin /usr/sbin /var/lib/mysql /usr/share/info /usr/share/man /usr/include/mysql /usr/lib/mysql /usr/share/mysql /usr/share/sql-bench /etc/apache2 uso Ubicacin de los programas MySQL y de sus scripts Ubicacin del servidor mysqld Archivos log y bases de datos Manual en formato info de Linux Manual en formato del comando man de Unix Cabeceras de cdigo fuente Archivos de librera Raz de MySQL. Mensajes de error, juegos de caracteres, ejemplos, Benchmarks Archivos de configuracin y soporte

instalacin en Linux tipo RedHat (como Fedora) Se suele usar la utilidad yum (o bien la utilidad grfica de instalacin de paquetes): yum install mysql-server Esto descarga los archivos necesarios y cambia la contrasea del administrador de la base de datos (la pide por teclado). Una vez instalado se usara el comando: service mysqld start Lanza el servidor MySQL y lo coloca como servicio del sistema. Si deseamos que sea un servicio que funcione desde el arranque del sistema, se hara: chkconfig --levels 235 mysqld on De esa forma en los niveles de ejecucin 2,3 y 5; el demonio de MySQL (el proceso servidor) se arranca desde el inicio. El cdigo: chkconfig --levels 235 mysqld off Elimina del arranque al servicio.

(27)

administracin de bases de datos


instalacin y configuracin de un Sistema Gestor de Bases de Datos

instalacin en Linux tipo Debian (como Ubuntu) En los Linux derivados de Debian (como Ubuntu) pueden instalar el servidor MySQL con: sudo apt-get install mysql-server Tambin se puede utilizar la herramienta grfica Synaptic para instalar el paquete de servidor de MySQL. Se pedir una contrasea administrativa y se habr arreglado el PATH, se habr colocado el archivo de configuracin en /etc/mysql/my.conf y se colocar como servicio de arranque el script /etc/init.d/mysql que permite que el servidor puede lanzarse automticamente durante el arranque. En todo momento podemos parar el servidor con: service mysqld stop y lanzar con: service mysqld start Adems podremos colocar el servicio mysql para que se inicie atomticamente mediante: update-rc.d mysqld defaults

(1.6.5) asegurando la instalacin


contraseas de usuarios
Hay que intentar desde el primer momento que la instalacin de MySQL no permita que los usuarios puedan sobrepasar sus privilegios y daar las bases de datos. Por ello hay que asegurar que todos los usuarios (y en especial los administrativos) tienen contrasea. En las instalaciones en Windows ya existen las cuentas de usuario y se las pone contrasea durante la instalacin. Sin embargo algunas instalaciones en Windows (las genricas) no tienen los usuarios preconfigurados. Para configurar inicialmente los usuarios se lanza el script (comentado anteriormente) mysql_install_db. Con ello en la tabla mysql.user dispondremos de los usuarios iniciales. En Windows hay un usuario root (superusuario) que tienen privilegios totales pero que solo puede acceder a la mquina local. Para permitir el acceso con esos privilegios desde otra mquina, se crea otro usuario root (durante la instalacin de MySQL se pregunta esa posibilidad). En Linux los usuarios root permiten el acceso local. Hay cuentas annimas (no tienen nombre de usuario) algunas para acceder de forma local y otras no. Para asegurar el acceso se deben poner contraseas a las cuentas annimas o bien eliminarlas. Para examinar la lista de usuarios se usa: SELECT user, host, password FROM mysql.user; Para cambiar la contrasea, por ejemplo: SET PASSWORD FOR 'root'@'localhost' = PASSWORD(Atrezzo); En el ejemplo se cambia la contrasea para el superadministrador root cuando accede de forma local. (28)

2 curso de administracin de sistemas informticos en red autor: Jorge Snchez www.jorgesanchez.net

Otra forma (mejor puesto que modifica de golpe la contrasea de todos los root) es: UPDATE mysql.user SET password=PASSWORD(Atrezzo) WHERE user=root; FLUSH PRIVILEGES; La ltima instruccin es la que hace que el cambio se lleve a cabo.

eliminacin de la base de datos ejemplo


En muchas instalaciones de MySQL se dispone de una base de datos llamada test que, en realidad, es para pruebas. Dejarla puede proporcionar un agujero de seguridad, por lo que si no deseamos usarla para aprender se debe de eliminar con: DELETE FROM mysql.db WHERE Db LIKE 'test%'; FLUSH PRIVILEGES; La ltima orden (FLUSH PRIVILEGES) confirma los cambios.

(1.7) instalacin de Oracle


(1.7.1) documentacin
Oracle tambin dispone de manuales de libre descarga en la direccin: http://download.oracle.com/docs/ Desgraciadamente toda la documentacin slo se encuentra en ingls.

(1.7.2) directorios de Oracle. comprender la estructura OFA


El SGBD comercial Oracle slo se puede instalar en sistemas Windows, Linux y Solaris. Normalmente se instala a travs del software conocido como Oracle Universal Installer (OUI), que al ser un programa Java, es el mismo en todas las plataformas. Por otro lado Oracle ha recomendado un estndar en las instalaciones que conviene seguir y conocer tanto si instalamos nosotros Oracle como si son otros los instaladores, ya que si son instaladores profesionales seguirn esta estructura. Se trata del Oracles Optimal Flexible Architecture (OFA). OFA impone la estructura de directorios y archivos en el sistema que Oracle debe utilizar. La razn es facilitar las tareas de administracin, especialmente las de aadir bases de datos, instalar software y administrar usuarios. Sus elementos fundamentales son las variables de sistema ORACLE_BASE y ORACLE_HOME. Cada versin de cada producto debera tener una versin diferente de estas variables que representan la ruta global a un directorio.

Oracle Base
El directorio Oracle Base, es la raz de las instalaciones de Oracle (de todos los productos, de todas las versiones). En el modelo OFA en Linux deben cumplir la forma: /pm/h/u

(29)

administracin de bases de datos


instalacin y configuracin de un Sistema Gestor de Bases de Datos

Donde: p. Es el nombre de un texto estndar que suele ser corto y conciso. EL ms usado es la letra u. Muchos instaladores usan la palabra ora. m. Es una expresin numrica que va de 01 a 09. h. Es el nombre de una carpeta estndar. Se suele usar el nombre app. u. El nombre del usuario DBA de la instalacin (por ejemplo oracle) La ruta ms habitual es: /u01/app/oracle En el caso de Windows la ruta sigue la expresin: \oracle\app y esta ruta debe estar en la raz de cualquier unidad de disco. Por ejemplo C:\oracle\app

Oracle Home
Se trata del directorio raz de una instalacin concreta de Oracle (Oracle 11g R2, Oracle 10g, etc.). Su ruta OFA es: ORACLE_BASE/product/versin/nombre_instalacin La versin es la versin del producto que se instala y el nombre de la instalacin es una cadena que ponen los instaladores de Oracle. Para los servidores Oracle se usa db seguida de un nmero, por ejemplo 1. Ejemplo de ruta completa Oracle Base Linux podra ser: /u01/app/oracle/11.2.1/db_1 En Windows: c:\oracle\app\product\11.2.1\db_1

ruta a los archivos de datos


La base de datos en el modelo OFA se almacena en un directorio llamado oradata que se debera encontrar dentro de la ruta a Oracle Base. Dentro de oradata se utiliza el nombre de instancia dada en la instalacin para almacenar la base de datos. Por ejemplo (Linux): /u01/app/oracle/oradata/orcl

Oracle Inventory Directory


Este directorio se comparte con todas las instalaciones de Oracle. Sirve para indicar qu productos hay instalados. En cuanto se instala el primero producto Oracle, comprueba a ver si existe directorio de inventario; de no ser as, se crea. Si puede respetar la estructura recomendada OFA, en Linux se instalar en la raz (por ejemplo /u01/app/oraInventory), de no ser as se instalar en el directorio del usuario que instala Oracle ($HOME/oracle/oraInventory). En Windows se coloca siempre en la carpeta de Oracle dentro de la carpeta de aplicaciones de Windows (por ejemplo en C:\Program files\Oracle\Inventory).

(30)

2 curso de administracin de sistemas informticos en red autor: Jorge Snchez www.jorgesanchez.net

Por otro lado Oracle dispone de un archivo que permite encontrar el inventario, que en Linux suele ser /etc/oraInst.loc y en Windows es la clave de registro: HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE\inst_loc

Oracle Network Files Directory


Se trata del directorio que contiene los archivos de configuracin de la red, en especial tnsnames.ora y listener.ora que contienen la configuracin fundamental. Se suele encontrar en la ruta: ORACLE_HOME/network/admin

(1.7.3) instalacin en Windows


prerrequisitos
Oracle en Windows requiere un PC con al menos 1 GB de RAM y el doble en virtual. Disco duro con al menos 5,35 GB y tarjeta capaz de mostrar 1024 X 768 pxeles como mnimo.

instalacin
Es aconsejable crear un usuario relacionado con Oracle con permisos administrativos y con l instalar el software. La razn: ser coherente con las rutas OFA comentadas anteriormente, que de otra forma harn referencia al usuario con el que instalemos Oracle sea o no relacionado con l. En Windows, las variables de entorno y casi cada detalle se hace de manera automtica sin intervenir previamente (a diferencia de la instalacin Linux) se ocupa Oracle.

(1)

Descargar los archivos ZIP correspondientes a nuestra instalacin y descomprimirles en la misma carpeta. Desde esa carpeta (suele llamarse database) lanzar el instalador (archivo setup.exe). Indicar correo electrnico al que Oracle enviar informacin sobre problemas crticos Indicar si deseamos con el instalador instalar ya la instancia de base de datos. Normalmente habra que elegir instalar slo la instancia (creando la base de datos despus disponemos de ms posibilidades).

(2) (3)

Ilustracin 3, Seleccin de la opcin de instalacin de base de datos deseada

(4)

Indicar si deseamos instalar una instancia nica de Oracle o bien instalar instancias mltiples (base de datos distribuida). Lo lgico, por ahora, es instalar una instancia nica (31)

administracin de bases de datos


instalacin y configuracin de un Sistema Gestor de Bases de Datos

Ilustracin 4, Seleccin del tipo de distribucin de base de datos a instalar

(5) (6)

Elegir los idiomas Elegir el tipo de instalacin. Enterprise es la opcin si deseamos instalar todas las posibilidades de Oracle.

Ilustracin 5, Edicin de base de datos deseada

(7)

Elegir la ubicacin de instalacin. Normalmente el instalador la crear de forma coherente; se indicarn la base general de Oracle y el Oracle Home del producto que se est instalando en base al esquema OFA. En cualquier caso se puede cambiar la disposicin segn comprobemos lo que ms nos interesa.

(32)

2 curso de administracin de sistemas informticos en red autor: Jorge Snchez www.jorgesanchez.net

Si el usuario de instalacin se llama Oracle, la instalacin de Oracle Base (si es que no hay) ser C:\app\oracle, el Oracle Home ser algo del tipo: C:\app\oracle\product\11.2.0\dbhome_1

Ilustracin 6, Ubicaciones del Oracle Base y el Oracle Home

(8)

Comprobacin de requisitos. Se comprueba si el hardware y el software cumplen el mnimo de Oracle. De ser as se comienza la copia de archivos.

variables de sistema
Conviene editar una serie de variables de sistema y configurarlas en Windows para su funcionamiento (por ejemplo desde Administrar Sistema de Windows) son: ORACLE_BASE. Por ejemplo al valor C:\app\oracle ORACLE_HOME. Por ejemplo a %ORACLE_BASE%\product\11.2.0\dbhome_1 PATH. Aadir la ruta %ORACLE_HOME%\bin

(1.7.4) instalacin en Linux


prerrequisitos
El Hardware requerido por Oracle 11g es: Al menos 1GB RAM Ms o menos la misma cantidad de archivo swap de intercambio (el comando free permite averiguar ambas cosas) 1 GB de espacio en el directorio /temp Hasta 5 GB de espacio libre en disco Resolucin de pantalla de 1024 x 768 En cuanto al software, se requiere: Linux de tipo Red Hat o SuSe Al menos versin 2.6 del kernel de Linux Los requisitos de Linux son muy exigentes y orientados claramente a las distribuciones Red Hat, de la que ha conseguido certificacin de su instalador. En las Debian por ejemplo (como la popular Ubuntu) se puede instalar, pero realizando maniobras en la lnea de comandos. Esta poltica de Oracle ha sido muy criticada por la comunidad de software abierto de Linux. (33)

administracin de bases de datos


instalacin y configuracin de un Sistema Gestor de Bases de Datos

Tambin se requiere una serie de paquetes que dependen de la distribucin que instalemos y que se pueden consultar en el archivo: Finalmente Oracle requiere crear usuarios y grupos pensados para ser utilizados con Oracle. Como mnimo se crea un grupo para los administradores (grupo dba), otro para los instaladores (oinstall) y se suele crear otro para los operadores (oper). Un usuario debe existir antes de la instalacin (se le suele llamar oracle), que pertenece tanto al grupo dba como a oinstall.

instalacin
La dificultad para explicar pasos exactos debido a la cantidad de distribuciones y problemas hace que los pasos varen mucho de una distribucin a otra. Los pasos generales y comunes son los siguientes:

(1)

Crear usuarios y grupos necesarios. Oracle recomienda crear tres grupos de usuarios: dba (administradores), oinstall (instaladores) y oper (operadores). Lo cual se hace (si disponemos de permisos de administracin del sistema) de esta forma: groupadd dba groupadd oinstall groupadd oper Para hacer que el usuario oracle pertenezca a dba y oinstall: useradd -g dba -G oinstall oracle Para adjudicarle una contrasea passwd oracle

(2)

Crear el directorio base de Oracle (ORACLE_BASE) que es partir del que colgarn todas las races (ORACLE_HOME) de las instalaciones de Oracle posteriores. Darle permisos de escritura al usuario oracle (ejemplo): mkdir -p /u01/app/oracle chown -R oracle:oinstall /u01/app/oracle chmod -R 775 /u01/app/oracle Instalar los paquetes necesarios. Pueden ser bastantes saber cules se hace consultando la documentacin de Oracle o en Internet. Desgraciadamente varan mucho y es casi imposible saber cules sin hacer esa consulta. Establecimiento de variables de entorno. Se trata de las variables: ORA_BASE que establece el directorio raz de todos los productos Oracle ORA_HOME, que establece el directorio raz de una instalacin concreta ORACLE_SID, que establece el identificador de la base de datos LD_LIBRARY_PATH, rutas a las libreras de Oracle PATH, que ya existir y que habr que aadirla la ruta al directorio bin de Oracle. DISPLAY. usando los valores localhost:0.0 que permiten

(3)

(4)

(34)

2 curso de administracin de sistemas informticos en red autor: Jorge Snchez www.jorgesanchez.net

(5)

Lanzar el instalador runInstall.sh suponiendo que se han descargado y extrado los archivos de instalacin y seguir los pasos, en los que se indica: Si es el primer producto Oracle instalado, la ubicacin del inventario; que ya se coment anteriormente. Valorar prerrequisitos para ver si el equipo es compatible. De no ser as la instalacin se para. Una vez instalado, al final se indica la ruta a dos scripts que se deben lanzar con el usuario root; oraInstRoot.sh para preparar el archivo oraInst.loc y root.sh que sirve para ajustar el servicio Una vez hecho esto, la instalacin del software de Oracle termina

(1.7.5) crear la base de datos


La base de datos no se tiene por qu crear durante la instalacin. Es posible hacerlo despus, tanto en Linux como en Windows. Normalmente se utiliza el asistente DBCA (Data Base Creator Assistant) que en Windows se encuentra en Inicio-Programas en el grupo de Oracle en el apartado de Herramientas de Configuracin bajo el nombre Asistente de Configuracin de Bases de Datos. En Linux es un archivo en la carpeta bin de la raz de Oracle (el ORACLE_HOME) llamado dbca; para funcionar correctamente se deben configurar las variables de entorno, ejemplo (Linux): export ORACLE_BASE=/u01/app/db11g export ORACLE_HOME=$ORACLE_BASE/product/11.2.0/dbhome_1 export PATH=$ORACLE_HOME/bin:$PATH export LD_LIBRARY_PATH=$ORACLE_HOME/lib:$LD_LIBRARY_PATH En ambos casos hay que configurar la conexin de red a Oracle. Lo que se conoce como el Listener. Un listener es un programa residente en memoria (un proceso) que sirve para escuchar lo que llega por un puerto de red y enviarlo a su destino correspondiente. Sin l, por lo tanto, Oracle no obtendra las peticiones por red. Los pasos completos para crear una base de datos son:

(1) (2) (3) (4) (5) (6) (7) (8)

Lanzar el Asistente de Configuracin de Red (en Linux es netca y se encuentra en la carpeta bin dentro de la raz de Oracle Home). Elegir Agregar un Listener. Elegir un nombre para l (lo habitual es LISTENER) Especificar el protocolo por el que se comunica (TCP normalmente) Elegir el nmero de puerto que utilizar (normalmente el 1521) Finalmente, salir del asistente (tras decir que no configuramos ms listeners) Lanzar el Asistente de Configuracin de Bases de Datos (en Linux, comando dbca) Avanzar y elegir Crear una base de datos (35)

administracin de bases de datos


instalacin y configuracin de un Sistema Gestor de Bases de Datos

Ilustracin 7, Asistente de conexin de red, a punto de crear el Listener

(9)

Avanzar y elegir Personalizar la base de datos, de esa forma no se crearn datos en la misma

Ilustracin 8, , EL asistente de configuracin de bases de datos de Oracle

(10)

En el paso siguiente hay que indicar el nombre de la base de datos (toda nuestra red usar ese nombre) y un identificador de la base de datos (sid). Normalmente se pone el mismo nombre en ambos apartados. Asegurar que la casilla que permite configurar el servidor Oracle con Enterprise Manager est activada. Lo dems dejarlo con sus valores por defecto y avanzar Establecer las contraseas para los usuarios administrativos (en especial para SYS y SYSTEM). Se puede elegir la misma para todos (vlido solo para sistemas en prueba) En la siguiente al principio al menos conviene elegir el sistema de archivos normal como sistema de almacenamiento, usar las ubicaciones de la plantilla y

(11) (12)

(13)

(36)

2 curso de administracin de sistemas informticos en red autor: Jorge Snchez www.jorgesanchez.net

se puede pulsar el botn Variables de ubicacin de archivos para analizar los directorios creados y las variables del sistema.

(14)

La siguiente permite configurar la recuperacin de Flash. Mediante Flash se consigue restaurar y recuperar el sistema. No conviene (salvo para crear configuraciones muy especficas), tocar sus valores por defecto Aqu es interesante marcar la casilla de Generar archivos de comandos, a fin de examinar los scripts que crea Oracle.

(15)

En la pantalla siguiente desactivar todas las casillas, excepto: Enterprise Manager Repository. El resto le aade funciones que no suelen ser necesarias en una base de datos estndar. Lo mismo ocurre con los componentes que aparecen al hacer clic en Componentes de datos estndar, conviene desactivar todos, a no ser que deseemos una de esas funciones; por otro lado todo se podra instalar despus. De esta forma aligeraremos la creacin.

Ilustracin 9, Conviene instalar slo lo necesario

(16)

La pantalla siguiente (cuatro pestaas) permiten modificar los parmetros de inicio de la base de datos. La mayora son opciones avanzadas, hay que manipularlas sabiendo muy bien lo que se hace. Las pestaas son: Memoria RAM. Permite indicar la memoria que dejar nuestro servidor para almacenar los datos dinmicos configurando lo que se permite que ocupe tanto los datos globales (SGA) como los propios de cada proceso (PGA) Bloque y conexiones simultneas. El tamao del bloque no se puede modificar despus. La razn para un tamao u otro es la velocidad de la base de datos y depende de la cantidad de datos de la misma. El otro valor (normalmente 150), permite limitar o ampliar el nmero de usuarios simultneos que pueden acceder a la base de datos. (37)

administracin de bases de datos


instalacin y configuracin de un Sistema Gestor de Bases de Datos

Juegos de caracteres. Permite elegir la forma de codificar el texto. En cualquier software actual se recomienda el uso de Unicode (urf-8); pero Oracle suele tomar por defecto la codificacin del Sistema Operativo. Modo servidor. Salvo que tengamos un grandsimo nmero de usuarios, conviene elegir dedicado, a fin de que a cada usuario le asignemos recursos independientemente. Otros parmetros estn accesibles a travs del botn Todos los parmetros de inicializacin. En la siguiente podremos examinar los nombres y configuracin de los archivos de datos. El botn Variables de ubicacin de archivos permite observar la configuracin de las variables importantes del sistema. Elegir Crear la base de datos, En todo caso podramos elegir crear script de creacin de base de datos y as examinar cmo seran los comandos manuales.

(17) (18)

Finalmente se nos informa de la instalacin. Es importante apuntar la pgina del Enterprise Manager para acceder a ella cuando lo necesitemos. Una vez iniciada la generacin de la base de datos, merece la pena estar atentos a los mensajes de Oracle a fin de entender el proceso y dnde se almacena cada elemento. En la ltima pantalla (si todo ha ido bien), se presentan los datos de la instalacin. Esos datos son fundamentales, entre ellos est la direccin del archivo de configuracin de Oracle ora.ini y la URL para entrar en el servidor de aplicaciones que gestiona la base de datos.

(19)

Ilustracin 10, Pantalla final del asistente de configuracin de bases de datos de Oracle

(38)

2 curso de administracin de sistemas informticos en red autor: Jorge Snchez www.jorgesanchez.net

conectar con la base de datos


La forma clsica de conectar con Oracle, es utilizar la utilidad SQL*Plus, que es un cliente bsico que permite enviar comandos a Oracle. Para utilizarlo, bastara con ir a la consola de comandos del sistema y escribir sqlplus:

Ilustracin 11, Pantalla desde la consola de SQL*Plus

control de la instancia de Oracle


En cuanto Oracle finaliza la instalacin, coloca como servicios que arrancan con el sistema, los necesarios para el funcionamiento de la instancia de la base de datos. La forma habitual de gestionar el funcionamiento de cada instancia de Oracle es mediante el programa Database Control. Cada instancia posee su propio Database Control, que en realidad es un programa llamado emctl que se encuentra en el directorio bin de cada Oracle Home. Desde la lnea de comandos, se permiten estos (suponiendo que el directorio bin del Oracle Home est accesible en el PATH del sistema): emtcl start dbconsole emtcl stop dbconsole emtcl status dbconsole Los dos primeros detienen o lanzan la consola. El tercero muestra informacin sobre Database Control (cmo acceder, estado actual, etc) El acceso al entorno de Database Control, llamado Enterprise Manager se hace desde http://nombreDeServidor:puerto/em Para saber exactamente la localizacin, basta con usar el comando emctl status dbconsole Eso permite acceder al control de la base de datos mediante el navegador de Internet. En la direccin ORACLE_HOME/install/portlist.ini se pueden consultar los puertos que usa Oracle para el Enterprise Manager. Desde este entorno se pueden realizar todas las operaciones de administracin con la base de datos. La forma de conexin es entrar con SYS (con opcin SYSDBA) y su contrasea. (39)

administracin de bases de datos


instalacin y configuracin de un Sistema Gestor de Bases de Datos

control del listener


Como ya se ha comentado; el programa capaz de escuchar por el puerto asignado a la base de datos, las peticiones a la misma, se conoce como Listener. Para gestionarle se usa el programa lsnrctl, disponible tambin en el directorio bin del Oracle Home. Sus posibilidades para lanzar o quitar el listener son: lsnrctl start nombreListener lsnrctl stop nombreListener lsnrctl status Tambin se puede lanzar desde el Enterprise Manager, y como servicio en el caso del entorno Windows.

conexin en modo administrador


Si usamos la sintaxis: sqlplus /nolog Entonces entramos en sql*plus sin indicar usuario, de otra forma el programa nos pedira usuario y contrasea para conectar. La opcin /nolog permite muchas formas de conectar. La forma ms avanzada de conectar es mediante CONNECT: CONNECT usuario/contrasea [@alias] [AS {SYSOPER | SYSDBA} ] Los usuarios normales no tienen capacidad de manejar la instancia de la base de datos. Slo los que tienen roles de DBA o privilegios para cortar e iniciar la instancia. A este respecto hay dos privilegios especiales que permiten a un usuario (que tenga la posibilidad de acceder en modo administrador) operaciones avanzadas en la base de datos, son: SYSOPER. Tiene capacidad de arrancar (STARTUP) detener una instancia (SHUTDOWN), adems de hacer modificaciones a las bases de datos y los tablespace. SYSDBA. Adems de lo anterior se le permite crear bases de datos, as como usuarios con privilegios SYSDBA y SYSOPER. Ejemplos de conexin: CONNECT adolfo/natura; --conecta como usuario normal CONNECT adolfo/natura@asir; --conecta como usuario normal indicando --a qu base de datos se conecta CONNECT adolfo/natura@asir AS SYSOPER; --dem pero indicando que --se conecta con rol de SYSOPER CONNECT / AS SYSDBA En la ltima no se indica usuario. Se recoger de las Windows que har posible la conexin siempre que ese usuario sea propietario del grupo Oracle (si es el administrador, se toma como usuario SYS). El comando para desconectar es DISCONNECT.

(40)

2 curso de administracin de sistemas informticos en red autor: Jorge Snchez www.jorgesanchez.net

manejo de la instancia de la base de datos


arranque Una base de datos Oracle puede estar en uno de estos cuatro estados: SHUTDOWN. La base de datos est cerrada, todos los archivos de la misma no estn en ejecucin. NOMOUNT. La instancia de base de datos est latente en memoria, con los procesos comunes funcionando. No es posible conectar con la base de datos. MOUNT. Al estado anterior se aade la lectura de los archivos de control para optimizar el funcionamiento de la instancia. Los usuarios no pueden conectar. OPEN. La base de datos est completamente lanzada y disponible a los usuarios. El comando que acepta estos estados es STARTUP. Pero ALTER DATABASE seguida de una de esas palabras permite modificar el estado actual. parada Una instancia cuando es arrancada, hasta estar disponible atraviesa todos los estados anteriores. El comando de apagado de la instancia es SHUTDOWN, su sintaxis: SHUTDOWN [NORMAL | TRANSACTIONAL | IMMEDIATE | ABORT] Las opciones son: NORMAL. No se admiten ms conexiones a la base de datos, pero las actuales se mantienen. Cuando se cierre la ltima, la base de datos tambin se cerrar. TRANSACTIONAL. Igual que la anterior, pero ahora se cortan todas las conexiones que no hayan empezado una transaccin. INMEDIATE. No se aceptan nuevas conexiones y se cortan las actuales. Las transacciones se cortan mediante una instruccin ROLLBACK, cuando se cancele la ltima, se apaga la instancia de base de datos ABORT. Apagado brusco. No se graba nada en disco. Simula un apagn. uso desde el Enterprise Manager

borrado de la base de datos


Requiere de estos comandos

(1) (2) (3)

Necesitamos cortar la instancia actual: SHUTDOWN INMEDIATE; Iniciar la base de datos en modo MOUNT STARTUP MOUNT EXCLUSIVE RESTRICT; Borrar DROP DATABASE;

(41)

administracin de bases de datos


instalacin y configuracin de un Sistema Gestor de Bases de Datos

Borrar una base de datos requiere de muchsima prudencia, ya que no se puede deshacer y podemos hacer desparecer cantidades enormes de datos importantes.

(1.8) diccionario de datos


Es fundamental poder consultar el diccionario de datos. Una de las reglas bsicas de toda base de datos relacional es que se pueda consultar la estructura de la base de datos utilizando las mismas instrucciones que permiten consultar datos. A travs del diccionario de datos podemos conocer los esquemas lgicos e internos de nuestras bases de datos.

(1.8.1) MySQL
MySQL dispone de una instruccin fuera del estndar SQL para consultar el diccionario de datos, es la instruccin SHOW. Tras esa palabra simplemente se indica lo que deseamos consultar. Por ejemplo: SHOW DATABASES; Muestra la lista de bases de datos accesibles actualmente. SHOW TABLES; Muestra la lista de las tablas del esquema actual de trabajo. Sin embargo tambin dispone de una forma ms estndar de consulta de los metadatos a travs de la base de datos INFORMATION_SCHEMA. Dentro de INFORMATION_SCHEMA se encuentran vistas de toda la estructura de metadatos de MySQL. Por ejemplo: SELECT table_name, table_schema FROM INFORMATION_SCHEMA.TABLES; muestra la lista de tablas en MySQL indicando el esquema en el que se encuentran alojadas. Las Vistas ms usadas son: Vistas del INFORMATION_SCHEMA TABLES COLUMNS USER_PRIVILEGES SCHEMA_PRIVILEGES TABLE_PRIVILEGES COLUMN_PRIVILEGES CHARACTER_SETS TABLE_CONSTRAINTS KEY_COLUMN_USAGE Uso Muestra todas las tablas accesibles desde nuestro usuario. Muestra las columnas de las tablas. Lista de privilegios de usuario Privilegios de esquema Muestra a los privilegios asignados a las tablas. Privilegios de columna Juegos de codificacin de caracteres disponibles Restricciones Columnas clave

(42)

2 curso de administracin de sistemas informticos en red autor: Jorge Snchez www.jorgesanchez.net

Vistas del INFORMATION_SCHEMA ROUTINES VIEWS TRIGGERS

Uso Procedimientos y funciones almacenados en la base de datos Vistas Lanzadores de cdigo

(1.8.2) Oracle
En el caso de Oracle, no utiliza el esquema estndar INFORMATION_SCHEMA para consultar el diccionario de datos, en su lugar usa una serie de vistas que comienzan con estos trminos: USER_ Las vistas que comienzan por esta palabra muestran objetos que pertenecen al usuario/a que hace la consulta ALL_ Muestra objetos a los que el usuario tiene acceso (sean o no de su propiedad). DBA_ Muestra todos los objetos de la base de datos As USER_TABLES es la vista que muestra todas las tablas del usuario actual. Otras vistas son (disponibles con el prefijo USER_, DBA_ o ALL_): Vistas del INFORMATION_SCHEMA TABLES COLUMNS SYS_PRIVS TAB_PRIVS VIEWS TRIGGERS Uso Muestra todas las tablas accesibles desde nuestro usuario. Muestra las columnas de las tablas. Lista de privilegios de usuario Privilegios de los objetos Vistas Lanzadores de cdigo

Otras vistas interesantes para los administradores son: Vistas del INFORMATION_SCHEMA V$INSTANCE V$SYSTEM_PARAMETER V$SESSION ROLES_SYS_PRIVS DBA_ROLES DBA_FREE_SPACE DBA_TABLESPACES DBA_TS_QUOTAS (43) Uso Muestra el estado de la instancia de la base de datos Parmetros del sistema Sesiones activas Lista de roles y privilegios Roles de privilegios del sistema Espacio libre en los tablespace Lista de Tablespaces Gasto de los usuarios en los tablespaces

administracin de bases de datos


instalacin y configuracin de un Sistema Gestor de Bases de Datos

(1.9) configuracin del sistema


(1.9.1) configuracin de MySQL. Uso de opciones
uso de opciones en la lnea de comandos
Se trata de acompaar a los comandos MySQL de opciones en la misma lnea en la que se lanza el comando a fin de modificar su funcionamiento. As por ejemplo el comando mysql que permite conectar con la base de datos, admite diversas opciones, por ejemplo la opcin --execute permite ejecutar un comando al comunicarse con la base de datos. Ejemplo: mysql -u root -p --execute=SHOW DATABASES; Muestra por pantalla directamente el resultado de la instruccin SQL. Muchas opciones admiten un formato corto que realiza exactamente esa operacin. Para el ejemplo, vale: mysql -u root -p -e SHOW DATABASES; Casi todos los comandos MySQL admiten opciones, pero el ms utilizado es mysqld, para verlas todas se usa: mysqld --help --verbose

uso de opciones desde el archivo de configuracin


Se puede configurar el funcionamiento de MySQL gracias al archivo my.cnf o my.ini. Como consejo, se debera de llamar my.cnf y as tanto en Windows como en Linux manejamos el mismo nombre. En la mayora de instalaciones se instala solo (bien en C:\Windows o bien /etc o en /etc/mysql); en otras tendremos que crearlo y eso es mejor hacerlo copiando los archivos de muestra de configuracin de la carpeta support-files (Linux) o de la raz de MySQL (Windows); el ms usado para es el mdium. Luego se modifican las opciones deseadas. El archivo de configuracin en Windows se puede usar de esta forma (en orden de cul se ejecuta primero): Ruta al fichero DirectorioWindows\my.ini c:\my.cnf DirectorioRazMYSQL\my.ini ---defaultExtraFile=ruta Mientras que en Linux Ruta al fichero /etc/my.cnf /etc/mysql/my.cnf $MYSQL_HOME/my.cnf (44) Opciones globales Opciones globales Opciones que se aplican al servidor entero Uso Opciones globales Opciones globales Usa como archivo de configuracin el de la ruta indicada Uso Opciones globales (se aplican a todos)

2 curso de administracin de sistemas informticos en red autor: Jorge Snchez www.jorgesanchez.net

Ruta al fichero (pero slo a l) ---defaultExtraFile=ruta ~/.my.cnf

Uso Usa como archivo de configuracin el de la ruta indicada Opciones especficas del usuario

En ese archivo de configuracin (y en cualquier otro de MySQL) hay que tener en cuenta que: Cualquier lnea que comience con el signo # indica un comentario (texto que no se tiene en cuenta y que solo sirve para documentar el propio archivo). El documento se divide en secciones, las cuales se indican mediante el nombre de la seccin encerrada entre corchetes (por ejemplo [mysqld]). La seccin se suele corresponder con una de las aplicaciones de MySQL, por ello hay seccin mysqld, mysqladmin, El resto son instrucciones que constan de una variable de sistema (tambin llamada simplemente opcin) seguida del signo = y del valor de dicha opcin. En la raz de instalacin del sistema (o en support-files en Linux) de MySQL hay una serie de archivos de configuracin que pueden servir de plantilla. Es decir estn pensados para ser copiados y modificados como archivo principal de configuracin. El nombre de estos archivos (my-small.cnf, my-medium.cnf, my-large.cnf y myhuge.cnf) hace referencia al tamao de las bases de datos que ha de manejar el servidor. algunas opciones del archivo my.cnf (o my.ini) Se comentan las ms utilizadas de la seccin mysqld (afectan al funcionamiento del servidor MySQL) basedir=ruta. Ruta a la raz MySQL datadir=ruta. Ruta al directorio de datos tmpdir=ruta. Ruta al directorio para archivos temporales user=usuario. Indica el nombre de usuario con el que se iniciar sesin en MySQL. port=puerto. Puerto de escucha de MySQL socket=ruta. Fichero o nombre de socket a usar en las conexiones locales. default-table-type=tipo. Tipo de la Tabla InnoDB, MyISAM o BDB normalmente general-log=valor. Con valor uno, permite que funcione el archivo LOG para almacenar las consultas realizadas. general-log-file=ruta. Indica la ruta al registro general de consultas log-error=ruta. Permite indicar la ruta al registro de errores. log=ruta. Indica la ruta al registro de consultas log-bin=ruta. Permite indicar la ruta al registro binario. slow-query-log=0|1. Indica si se hace LOG de las consultas lentas. slow-query-log-file=ruta. Ruta al archivo que hace LOG de las consultas lentas (45)

administracin de bases de datos


instalacin y configuracin de un Sistema Gestor de Bases de Datos

long-query-time=n. Segundos a partir de los cuales una consulta que tardes ms, se considerar una consulta lenta. pid-file=ruta. Ruta al archivo que almacena el identificador de proceso de MySQL console. Muestra los errores por consola independientemente de lo que se configue para log_error. flush. Graba en disco todos los comandos SQL que se ejecuten (modo de trabajo, sin transaccin) language. Especifica el idioma de los lenguajes de error, normalmente esots archivos de lenguaje, estn bajo /usr/local/share skip-grant-tables. Entra al servidor saltndose las tablas de permisos, es decir todo el mundo tiene privilegios absolutos skip-networking. El acceso a MySQL se har solo desde el servidor local. standalone. Para Windows, hace que el servidor no pase a ser un servicio.

(1.9.2) configuracin de Oracle


Al igual que MySQL, los comandos de Oracle tienen parmetros posibles para enviar. Normalmente los parmetros se configuran en archivos especiales que son ledos por la instancia de Oracle antes de iniciarse, para as hacerlo con la configuracin que indica el archivo (o archivos) de parmetros. EL archivo de parmetros puede ser:

(1) (2)

Un archivo de texto. Un archivo binario SPFILE.

La recomendacin actual es utilizar un archivo binario, ya que permite su modificacin mediante el comando SQL: ALTER SYSTEM y porque en binario la configuracin queda ms oculta.

archivos de parmetros de texto


Oracle puede utilizar un archivo de texto para almacenar parmetros. Su ubicacin es: Linux/Unix. Est en ORACLE_HOME/dbs/initSID.ora. Por ejemplo: /u01/app/oracle/11.2.1/db_1/dbs/initbbdd.ora Windows. Est en ORACLE_HOME\database\initSID.ora En estos archivos los parmetros se marcan as: parmetro=valor El valor puede ser una lista de valores separados por comas. Los comentarios se ponen con el smbolo #. Algunos parmetros muy utilizados son: db_name=nombre. Identificador de la base de datos db_domain=dominio. Dominio al que pertenece la base de datos control_files=ruta. Ruta a los archivos de control que se indique. Si no se indicara alguno, se crea en el directorio del archivo de parmetros processes=nmero. Mximo nmero de procesos que podr lanzar la base de datos. (46)

2 curso de administracin de sistemas informticos en red autor: Jorge Snchez www.jorgesanchez.net

sessions=nmero. Mximo nmero de sesiones concurrentes que se permiten. socket=ruta. Fichero o nombre de socket a usar en las conexiones locales. log_archive_dest_n. Permite indicar el destino del archivos LOG de tipo REDO. n puede ser un valor entre 1 y 31 (nmeros de archivo) y despus se puyeden indicar un rosario de opciones para controlar exactamente lo que se graba. db_recovery_file_dest=ruta. Permite recuperacin de la base de datos. indicar un directorio para la

archivos SPFILE de parmetros


SPFILE es el acrnimo de Server Parameter File y es otra forma de establecer parmetros. Para usar el archivo SPFILE en lugar del archivo de texto se usa esta instruccin: CREATE SPFILE [=rutaAlArchivoSPFILE] FROM [PFILE='rutaAlArchivoDetTexto' | MEMORY] Con esa instruccin se crea un archivo SPFILE por defecto a partir del contenido del archivo de parmetros de texto (llamado PFILE) indicado, o a partir de los parmetros actualmente en uso (opcin MEMORY). El archivo SPFILE por defecto (si no se indica ruta) estar en el mismo directorio que el de texto, solo que ahora en lugar de llamarse por ejemplo initdb1.ora sera spfiledb1.ora. Si en la instruccin anterior se indica destino para el SPFILE, entonces se tomar como copia de seguridad, ya que el que acta es el archivo por defecto. Los parmetros que se desea modificar, se configuran con la instruccin ALTER SYSTEM SET; algunos son dinmicos (su efecto se produce inmediatamente) y otros estticos (su efecto se produce tras el arranque). La sintaxis es: ALTER SYSTEM SET parmetro=valor [COMMENTS = comentarios] [SCOPE={SPFILE | MEMORY | BOTH }] SCOPE controla cuando se produce el efecto del parmetro: SPFILE. Significa que el comando modifica el archivo de parmetros SPFILE y sus efectos se vern en el siguiente arranque. MEMORY. El cambio se graba en memoria y se produce inmediatamente; pero como no toca el archivo SPFILE, su efecto no ser inmediato. BOTH. Hace ambas cosas. El comando SHOW PARAMETERS muestra los parmetros que actan en la sesin actual; SHOW SPPARAMETERS muestra los del archivo SPFILE que sea el actual. La vista V$PARAMETER contiene los parmetros actuales de la sesin, V$SYSTEM_PARAMETER contiene los parmetros del sistema y V$SPFILE los del archivo SPFILE se usen o no.

(47)

administracin de bases de datos


instalacin y configuracin de un Sistema Gestor de Bases de Datos

(1.10) archivos LOG


Se trata de los archivos que permiten auditar el funcionamiento de la base de datos. Son importantes para determinar lo que ha ocurrido en el servidor en el caso de que ocurriera algo anmalo.

(1.10.1) ficheros LOG en MySQL


Hay cuatro registros (logs): Registro de errores (Error Log). Indica cuando arranc y se detuvo el servidor. Se graba por defecto en la carpeta de datos de MySQL (archivo host_name.err, donde host_name es el nombre del servidor), pero la variable de sistema log_error permite indicar otra ruta si fuera necesario. Registro general de consultas (General Log File). Est en la carpeta de datos de MySQL, salvo que se indique la variable general-log-file. Contiene las consultas realizadas. Es el archivo host_name.log. Registro binario (Binary Log). Registra instrucciones DML. Los archivos binarios se almacenan por defecto en el directorio de datos. Sirve para intentar restaurar una base de datos en caso de desastre. Es binario, por lo que su manejo es complicado, para ver el contenido se usa la utilidad mysqlbinlog de esta forma: mysqlbinlog archivoLOG Registro de consultas lentas (Slow Query Log File). Registra las consultas que tardaron un poco del tiempo mnimo establecido. El archivo est (salvo quese especifique slow-log-file como parmetro) en la carpeta de datos de MySQL con el nombre host_name-slow.log.

(1.10.2) ficheros LOG en Oracle


Hay mltiples archivos LOG para monitorizar los distintos aspectos de Oracle. Entre ellos: alert LOG. Registra sucesos de la gestin general de la BD. LOG de procesos en background. Registra los sucesos provocados por los procesos en ejecucin de Oracle. LOG de usuarios. Monitoriza la actividad de los usuarios. Se gestionan normalmente con el Enterprise Manager, pero es posible hacerlo con las vistas del diccionario de datos, como V$DIAG_INFO para el alert log, En temas posteriores se vern todos los archivos LOG y sus posibilidades.

(48)

Anda mungkin juga menyukai