• No results found

Evaluative and cognitive aspect as applied to religious background

Chapter 4. Theoretical foundation of the study

4.4. Evaluative and cognitive aspect as applied to religious background

En función de las características de los datos a almacenar deberemos elegir el sistema de persistencia más adecuado. Para ello analizamos diferentes sistemas y sus características contrastándolos con los grupos de datos que maneja la aplicación:

Ficheros de texto secuenciales: Son ficheros en texto plano escritos por líneas y de recorrido secuencial. Su actualización se realiza añadiendo líneas al final del fichero pudiendo crecer indefinidamente de forma ordenada en el tiempo. Son fácilmente accesibles tanto por aplicaciones externas como directamente por los administradores. Por estas características son el sistema más ampliamente utilizado para el almacenamiento de los logs de eventos y acciones del sistema y aplicaciones.

Para poder controlar el volumen ocupado en disco por estos ficheros, que crecen indefinidamente a medida que el sistema genera eventos y realiza acciones, se utilizan técnicas de rotación. Para ello se define un tamaño máximo de fichero y un número de ficheros máximo, cuando el primer fichero alcanza su capacidad máxima es renombrado con un código definido y se continúan registrando entradas en un fichero nuevo. Cuando el sistema de logs alcanza el límite de ficheros establecido se descarta el más antiguo, o se desplaza a otra localización de almacenamiento masivo para su conservación, quedando de esta forma un hueco libre, se renombran los demás ficheros de forma adecuada y se continúa en uno nuevo, controlando así el tamaño máximo que los ficheros pueden ocupar en el sistema de monitorización.

Ficheros estructurados: A diferencia de los ficheros secuenciales, los ficheros estructurados constan de una estructura prefijada para almacenar los datos. Existen varias definiciones o lenguajes estándar como XML [23] o la estructura definida en SMI (Structure of Management Information) para las MIBs en SNMP. Esta estructura permite definir una serie de algoritmos o reglas de lectura para obtener la información almacenada y tratarla de la manera que le corresponda.

CAPÍTULO 2. ESTADO DE LA CUESTIÓN. 27

Ya sea utilizando un formato estándar definido o diseñando uno específico para la aplicación este tipo de ficheros son los más adecuados para almacenar las configuraciones tanto de la aplicación como de los diferentes módulos. También resultan adecuados para definir reglas de comportamiento en forma de scripts de código al ser los lenguajes de programación lenguajes estructurados según una serie de reglas definidas por sus gramáticas.

Ficheros serializados: Los ficheros serializados son el resultado de aplicar un proceso de aplanado o “marshalling” sobre las estructuras en memoria de una aplicación, de forma que posteriormente puedan ser leídos para reconstruir fielmente la misma estructura en memoria en otra ejecución o en otra aplicación. De esta forma se podrán crear diferentes estructuras y almacenarlas para su posterior recarga ahorrando el proceso de diseño de las mismas en cada uso.

Es una técnica ampliamente utilizada para dotar de persistencia a modelos de objetos, tanto para su almacenamiento como para su transmisión en red a otras aplicaciones. Muchos lenguajes de programación, como: Java, Delphi, C#, Perl, Python por citar algunos, incluyen librerías para realizar este proceso de forma nativa, lo que la hace la técnica más adecuada para almacenar la estructura de red en memoria durante la ejecución del sistema de monitorización.

Ficheros binarios: Un fichero binario simplemente es aquel en que la información ha sido codificada antes de almacenarse en lugar de escribirse directamente en texto plano. Cualquiera de los modelos de ficheros anteriormente comentados pueden ser escritos en texto pero su almacenamiento binario permite compactar los datos aprovechando el espacio, de forma que el fichero final no solo no es legible directamente por usuarios si no que requiere de algún mecanismo específico para recuperar los datos. Por esto resulta una técnica recomendable a la hora de generar ficheros, tanto de cara a ahorrar espacio en el sistema como para asegurar cierto nivel de seguridad en los mismos. Pudiéndose, además, aplicar técnicas de cifrado, firmado etc. sobre los mismos.

Bases de datos relacionales: Las bases de datos relacionales son el modelo de persistencia más utilizado actualmente para cualquier tipo de datos estructurado. En ellas se definen una serie de entidades con atributos y unas relaciones que posteriormente son transformadas en tablas que se almacenan en el sistema gestor de bases de datos. Estos sistemas definen operaciones estándar de creación, lectura, escritura y borrado de datos, CRUD (Create, Read, Update, Delete) además de otras funcionalidades de gestión del sistema gestor.

La información almacenada en ellas es accesible de forma estándar por cualquier sistema que las conecte. Los sistemas gestores están desarrollados de forma independiente y altamente optimizados para la gestión, acceso y almacenamiento de información, estando además dotados de sus propios sistemas de comunicación en red. Resultan por ello un método muy adecuado para almacenar información estructurada según el modelo relacional, entidades con atributos y relaciones similar al modelo de clases de la programación orienta a objetos o estructurada en tablas.

28 CAPÍTULO 2. ESTADO DE LA CUESTIÓN.

Así mismo también resulta adecuado para cualquier otro tipo de información no estructurada como puedan ser algunos ficheros al permitirse almacenar estos como el valor de un campo en una de las tablas, resultando totalmente independiente de la aplicación.

Bases de datos Round Robin: Las bases de datos round robin están específicamente diseñadas para almacenar historiales de datos variables en el tiempo obtenidos a intervalos regulares. Son capaces de interpolar datos tanto internos a los intervalos como datos no recibidos y definen un volumen máximo de almacenamiento de una forma similar a los ficheros rotatorios expuestos anteriormente. Combinando estas características resultan un mecanismo de persistencia muy adecuado a información de monitorización de todo tipo y por ello es ampliamente utilizado por estos sistemas siendo una de las características listadas en las comparativas de sistemas de monitorización.

RRDTool [17] es el estándar de código abierto de implementación de este sistema de almacenamiento, es multiplataforma y dispone de librerías para su uso bajo diferentes lenguajes de programación.

2.5. Paradigma de programación a emplear: Orientación a Objetos

Dentro de los diferentes paradigmas de programación destaca la programación orientada a objetos, la cual es, actualmente, el paradigma más extendido para el desarrollo de aplicaciones en general. Entre sus principales características destaca la independencia existente entre sus componentes tanto a nivel de diseño como de implementación lo cual permite realizar diseños altamente modulares y actualizables.

2.5.1. Conceptos

Este paradigma define una serie de conceptos abstractos en función de los cuales se definen todos los componentes del problema, datos y comportamientos, y las relaciones existentes entre ellos:

Clase: El principal elemento conceptual, las clases, son una representación abstracta de un concepto real del problema y engloban tanto su estado, conjunto de información relativa al elemento en un momento dado y su comportamiento. Las clases son elementos con independencia total, a excepción de las herencias, del resto de elementos del diseño e incluso del diseño mismo. Una clase que represente un concepto concreto podrá ser reutilizada tal cual en otra aplicación sin necesidad de recodificarla, simplemente con trasladarla al diseño nuevo.

Permite también, gracias a la ocultación, poder reemplazar un diseño o implementación de una clase por otra que represente el mismo concepto sin necesidad de propagar cambios al resto del diseño o código. Estas características dotan de una gran capacidad de actualización del software desarrollado bajo este paradigma al tiempo que diferencia claramente los elementos conceptuales del diseño, lo que permite a tanto a los desarrolladores como a los clientes comprender fácilmente el diseño del sistema.

CAPÍTULO 2. ESTADO DE LA CUESTIÓN. 29

Atributos y Métodos: Las clases contienen dos “tipos” de elementos o conceptos: los atributos y los métodos. Ambos son características implícitas de una clase y la principal diferencia entre ambos es que los atributos representan una característica o subcomponente y los métodos un comportamiento o reacción. Se podría decir que los atributos definen “como es” y los métodos “como actúa”. Pudiendo ambos a su vez ser definidos como clases el conjunto de clases de un sistema queda relacionado mediante una jerarquía de relaciones “contiene”, “forma parte de” o “conoce a” y no existen elementos en el sistema que no estén definidos por una clase.

Herencia: Otro concepto existente es la herencia representando relaciones “es un”. La herencia permite definir subclases que, heredando de una o varias clases padres, las especifica o completa añadiendo atributos concretos o métodos específicos. Esto permite realizar diferentes niveles de abstracción a la hora de diseñar un modelo para el problema, permitiendo agrupar elementos diferentes bajo un mismo concepto común para ambos unificando en la clase padre los métodos o atributos comunes a las clases hijo.

Objeto: Siendo las clases y sus relaciones una representación abstracta de conceptos los objetos son la instanciación real de esas clases. Una clase puede tener al mismo tiempo múltiples instancias, objetos, de sí misma, cada una de ellas con un estado o valor de atributos y un estado de comportamiento, métodos en ejecución. Estos objetos se comunicarán entre ellos mediante mensajes, llamadas a los métodos de otros objetos conocidos, según queda definido en el diseño abstracto a nivel de clases. Los objetos son los encargados de representar los elementos reales del problema durante la ejecución de la aplicación, representando así un estado específico del problema y, colaborando entre ellos mediante los mensajes, realizaran la labor destinada a la aplicación.