Computación autónoma

De Wikipedia, la enciclopedia libre

La computación autónoma (en inglés: autonomic computing, AC) son recursos informáticos distribuidos con características de autogestión, que se adaptan a cambios impredecibles mientras ocultan su complejidad intrínseca a los operadores y usuarios. Iniciada por IBM en 2001, esta iniciativa tenía como finalidad desarrollar sistemas informáticos capazes de autogestionarse, superar el rápido incremento en la complejidad de la gestión de sistemas informáticos y reducir el obstáculo que plantea la complejidad para un mayor desarrollo.[1]

Descripción[editar]

El objetivo de sistema AC es la toma de decisiones adaptativas haciendo uso de políticas de alto nivel. Comprobará y optimizará constantemente su estado y se adaptará automáticamente a condiciones variables. El espacio de trabajo de la computacion autónoma se compone de componentes autónomos (AC) que interactúan entre sí. Un sistema AC se puede modelar en términos de dos esquemas de control principales: local y global, los cuales cuentan con sensores (para automonitoreo), efectores (para autoajuste), conocimiento y planificador/adaptador para explotar políticas basadas en la conciencia de uno mismo y del entorno. Esta arquitectura a veces se denomina como Monitor-Analyze-Plan-Execute (MAPE).

La computación orientada a la autonomía es un paradigma propuesto por Jiming Liu en 2001 que utiliza sistemas artificiales que imitan los comportamientos colectivos de los animales sociales para resolver problemas computacionales difíciles. Por ejemplo, la optimización de colonias de hormigas podría ser un caso de estudio en este paradigma.[2]

Problema de complejidad creciente[editar]

Se prevé que los dispositivos informáticos en uso aumentarán un 38% al año,[3]​ a la vez que la complejidad media de cada dispositivo va en aumento.[3]​ Actualmente, este volumen y complejidad es manejado por personas altamente calificadas; pero la demanda de personal de TI calificado ya está superando la oferta, con costos de mano de obra superiores a los costos de equipo en una proporción de hasta 18:1.[4]​ Los sistemas informáticos han aportado grandes facilidades en cuanto a velocidad y automatización, aunque ahora existe una grean necesidad por automatizar su mantenimiento para ahorrar gastos.

En un artículo de IEEE Computer en 2003, Kephart y Chess[1]​ advierten que la ambición por la interconectividad de los sistemas y dispositivos informáticos podría convertirse en la "pesadilla de la informática generalizada" en la que los arquitectos de sistemas serían incapaces de anticipar, diseñar y mantener la complejidad de las interacciones. Afirman que la esencia del cómputo autónomo es un sistema de autogestión, liberando administradores de tareas de mantenimiento de nivel bajo y a la vez presentar un mejor comportamiento de sistema.

Un problema general de los sistemas informáticos distribuidos modernos es que su complejidad, y en particular la complejidad de su gestión se está convirtiendo en un factor limitante en su desarrollo. Grandes empresas e instituciones están empleando redes informáticas a gran escala para la comunicación y la computación. Las aplicaciones distribuidas que se ejecutan en estas redes informáticas son diversas y se ocupan de muchas tareas, que van desde los procesos de control interno hasta la presentación de contenido web para la atención al cliente.

Adicionalmente, la computación móvil se abre camino entre estas redes a una velocidad cada vez mayor pues los empleados necesitan comunicarse con sus empresas mientras no están en su oficina. Lo hacen mediante el uso de ordenadores portátiles, asistentes digitales personales, o teléfonos móviles con diversas formas de tecnologías inalámbricas para acceder a los datos de sus empresas.

Esto crea una enorme complejidad en la red informática global lo cual es difícil de controlar manualmente por operadores humanos. El control manual consume bastante tiempo, es costoso y propenso a errores. El esfuerzo manual que se necesita para controlar un sistema infórmatico tiende a incrementar rápidamente.

El 80 % de estos problemas en la infraestructura ocurren al nivel de la base de datos y aplicaciones específicas del cliente.[cita requerida] La mayoría de los proveedores de servicios 'autónomos' se encargan del nivel más básico de trabajo (energía, hardware, sistema operativo, red y parámetros básicos de la base de datos).

Características de los sistemas autónomos[editar]

Una posible solución podría ser permitir a los sistemas informáticos de red a gestionarse por sí mismos sin intervención humana directa. La Iniciativa del Cómputo Automático (en inglés: Autonomic Computing Initiative, ACI) planea proveer la base para los sistemas autónomos. Está inspirado por el sistema nervioso autónomo del cuerpo humano.[5]​ Este sistema nervioso controla funciones importantes del cuerpo humano de manera inconsciente.

En un sistema autónomo autogestionado, el operador humano toma un nuevo rol: en lugar de controlar el sistema directamente, define políticas y reglas generales que guían el proceso de autogestión. Para este proceso, IBM definió los siguientes cuatro tipos de propiedades denominadas propiedades self-star (también llamadas self -*, self-x o auto -*).[6]

  1. Autoconfiguración (self-configuration): Configuración automática de componentes;
  2. Autorreparación (self-healing): Descubrimiento automático y corrección de fallas;[7]
  3. Autooptimización (self-optimization): Monitoreo y control automático de los recursos para asegurar el funcionamiento óptimo respetando los requisitos definidos;
  4. Autoprotección (self-protection): Identificación proactiva y protección frente a ataques arbitrarios.

Otros como Poslad[6]​ y, Nami y Sharifi[8]​ se han expandido en el set de self-star de la siguiente manera:

  1. Autorregulación: Un sistema que opera para mantener algún parámetro, p. ej., Calidad de servicio, dentro de un rango de reinicio sin control externo;
  2. Autoaprendizaje: Sistemas que utilizan técnicas de aprendizaje automático como aprendizaje sin supervisión el cual no requiere control externo;
  3. Autoconciencia (también llamado autoinspección y Autodecisión): El sistema debe conocerse a sí mismo. Debe conocer el alcance de sus propios recursos y los recursos a los que se vincula. Un sistema debe ser consciente de sus componentes internos y enlaces externos para poder controlarlos y administrarlos;
  4. Autoorganización: Estructura del sistema manejada por modelos de tipo físico sin presión explícita o participación desde fuera del sistema;
  5. Auto-creación (también llamada Autoensamblaje, Autorreplicación): Sistema impulsado por modelos de tipo ecológico y social sin presión explícita o participación externa al sistema. Los miembros de un sistema son auto motivados y auto impulsados, generando complejidad y orden en una respuesta creativa a una demanda estratégica en constante cambio;
  6. Autogestión (también llamada autogobierno): Un sistema que se gestiona a sí mismo sin intervención externa. Lo que se gestiona puede variar en función del sistema y la aplicación. La autogestión también se refiere a un conjunto de procesos de estrella propia, como la computación autónoma, en lugar de un solo proceso de estrella propia;
  7. Autodescripción (también llamada autoexplicación o autorrepresentación): Un sistema se explica a sí mismo. Es capaz de ser entendido (por los humanos) sin más explicación.

IBM ha establecido ocho condiciones que definen un sistema autónomo:[9][10]

El sistema debe

  1. Conocer a que recursos tiene acceso, cuáles son sus capacidades y limitaciones; y de que manera se relaciona con otros sistemas.
  2. Ser capaz de configurarse y reconfigurarse automáticamente dependiendo del entorno informático cambiante;
  3. Ser capaz de optimizar su rendimiento para garantizar el proceso informático más eficiente;
  4. Ser capaz de solucionar los problemas encontrados mientras se repara a sí mismo o al desviar las funciones del problema;
  5. Detectar, identificar y protegerse contra diversos tipos de ataques para mantener la seguridad e integridad general del sistema;
  6. Adaptarse a su entorno a medida que cambia, interactuando con los sistemas vecinos y estableciendo protocolos de comunicación;
  7. Depender de estándares abiertos y no puede existir en un entorno propietario;
  8. Anticipar la demanda de sus recursos sin dejar de ser transparente para los usuarios.

Aunque el propósito y comportamiento de los sistemas autónomos varían de un sistema a otro, cada sistema autónomo debe tener las siguientes propiedades para cumplir su propósito:

  1. Automático : Esto esencialmente significa ser capaz de autocontrolar sus funciones y operaciones internas. Como tal, un sistema autónomo debe ser autónomo y capaz de ponerse en marcha y funcionar sin ninguna intervención manual o ayuda externa. El conocimiento requerido para arrancar el sistema (Know-how) debe ser inherente al sistema.
  2. Adaptativo : Un sistema autónomo debe poder cambiar su funcionamiento (es decir, su configuración, estado y funciones). Esto permitirá que el sistema haga frente a los cambios temporales y espaciales en su contexto operativo, ya sea a largo plazo (personalización/optimización del entorno) o a corto plazo (condiciones excepcionales como ataques maliciosos, fallas, etc.).
  3. Consciente : Un sistema autónomo debe poder monitorear su contexto operativo, así como su estado interno para poder evaluar si su operación actual cumple su propósito. Esto le permite controlar la adaptación de su comportamiento operativo en respuesta al contexto o cambios de estado.

Niveles evolutivos[editar]

IBM definió el modelo de implementación autónoma, el cual contiene cinco niveles evolutivos para la implementación de sistemas autónomos:

  • El nivel 1 presenta la situación actual en la que los sistemas se gestionan esencialmente de forma manual.
  • Los niveles 2 a 4 introducen funciones de gestión cada vez más automatizadas.
  • El nivel 5 representa el objetivo final de los sistemas autonómicos y de autogestión.[11]

Patrones de diseño[editar]

La complejidad del diseño de los sistemas autónomos se puede simplificar mediante la utilización de patrones de diseño como el patrón modelo-vista-controlador (MVC) para mejorar la separación de preocupaciones al encapsular preocupaciones funcionales.[12]

Circuitos de control[editar]

Un concepto básico que se aplicará en Sistemas Autonómicos es el decircuitos de control cerrados . Este conocido concepto proviene de la Teoría de Control de Procesos . Esencialmente, un circuito de control cerrado en un sistema de autogestión monitorea algún recurso (componente de software o hardware) y de manera autónoma trata de mantener sus parámetros dentro de un rango deseado.

De acuerdo con IBM, se espera que cientos o incluso miles de estos circuitos de control funcionen en un sistema informático autogestionado a gran escala.

Modelo conceptual[editar]

Un componente fundamental de un sistema autónomo es la capacidad de detección ( Sensores Si ), que permite al sistema observar su contexto operativo externo. Inherente a un sistema autónomo es el conocimiento del propósito (intención) y el Know-how para operar en sí mismo (por ejemplo, arranque, conocimiento de configuración, interpretación de datos sensoriales, etc.) sin intervención externa. La operación real del sistema autónomo está dictada por la Lógica, que es responsable de tomar las decisiones correctas para servir a su Propósito, e influenciada por la observación del contexto operativo (basado en las entradas del sensor).

Este modelo destaca el hecho de que la operación de un sistema autónomo está impulsada por un propósito. Esto incluye su misión (p. ej., el servicio que se supone que debe ofrecer), las políticas (p. ej., que definen el comportamiento básico) y el "instinto de supervivencia". Si se ve como un sistema de control, esto se codificaría como una función de error de retroalimentación o, en un sistema heurísticamente asistido, como un algoritmo combinado con un conjunto de heurísticas que limitan su espacio operativo.

Véase también[editar]

Referencias[editar]

  1. a b Kephart, J.O.; Chess, D.M. (2003), «The vision of autonomic computing», Computer 36: 41-52, doi:10.1109/MC.2003.1160055 .
  2. Jin, Xiaolong; Liu, Jiming (2004), «From Individual Based Modeling to Autonomy Oriented Computation», Agents and Computational Autonomy, Lecture Notes in Computer Science 2969, p. 151, ISBN 978-3-540-22477-8, doi:10.1007/978-3-540-25928-2_13 .
  3. a b Horn. «Autonomic Computing:IBM's Perspective on the State of Information Technology». Archivado desde el original el 16 de septiembre de 2011. 
  4. 'Trends in technology', survey, Berkeley University of California, USA, March 2002
  5. «What is Ubiquitous Computing (Pervasive Computing)?». IoT Agenda (en inglés). Consultado el 26 de abril de 2023. 
  6. a b Poslad, Stefan (2009). Autonomous systems and Artificial Life, In: Ubiquitous Computing Smart Devices, Smart Environments and Smart Interaction. Wiley. pp. 317-341. ISBN 978-0-470-03560-3. Archivado desde el original el 10 de diciembre de 2014. Consultado el 17 de marzo de 2015. 
  7. S-Cube Network. «Self-Healing System». 
  8. . Third International Conference on Autonomic and Autonomous Systems (ICAS'07) 228. 2007. pp. 26-30. ISBN 978-0-387-44639-4. doi:10.1007/978-0-387-44641-7_11. 
  9. «IBM Research | Autonomic Computing | Overview | The 8 Elements». Archivado desde el original el 12 de agosto de 2004. Consultado el 27 de diciembre de 2021. 
  10. «What is Autonomic Computing? Webopedia Definition». 22 de junio de 2004. 
  11. «IBM Unveils New Autonomic Computing Deployment Model». IBM. 21 de octubre de 2002. 
  12. Curry, Edward; Grace, Paul (2008), «Flexible Self-Management Using the Model–View–Controller Pattern», IEEE Software 25 (3): 84, doi:10.1109/MS.2008.60 .

Enlaces externos[editar]