Páginas

martes, 28 de mayo de 2019

Por qué adoptar prácticas DevOps


Hoy en día independientemente del tipo de negocio en que una empresa esté  involucrada, la dependencia del software es enorme. La forma de construir y entregar  software dicta en gran medida el éxito o fracaso del negocio en cuestión.
Para la puesta en marcha de un nuevo software, es necesario por una parte construirlo o como normalmente se llama a esta actividad desarrollarlo. Una vez desarrollado es necesario desplegarlo, es decir instalarlo en los servidores desde los cuales dará servicio y por lo tanto se podrá hacer uso de su funcionalidad. En este escenario no debemos olvidar hablar de la necesidad de mantenimiento del software. Los negocios, las leyes, las normas, las modas, en definitiva el mundo cambia y el software construido ha de ser modificado para adecuarse a las necesidades de cada momento.
Las actividades de desarrollo y despliegue las llevan a cabo distintas personas que tienen conocimientos distintos y complementarios. Hay especialistas en desarrollo y especialistas en despliegue o instalación de software. Los primeros se denominan DEVelopers en inglés y los segundos OPerators. Los developers o profesionales de desarrollo diseñan y construyen software y su objetivo es estar siempre cambiando el software para mejorarlo y crear nuevas funcionalidades, en definitiva estar siempre “cambiando”. Los operators o  profesionales de operaciones por su parte, tienen la misión de mantener el software permanentemente dando servicio, impidiendo que se produzcan fallos y caídas inesperadas, en definitiva mantener la “estabilidad”.
Aunque developers y operators tienen el mismo objetivo final, resulta que sus objetivos individuales suelen entrar en conflicto. Si queremos algo estable (operators), los cambios no son bienvenidos (developers).
DevOps es una forma de dar nombre a un conjunto de buenas prácticas que tienen en cuenta esta dicotomía de intereses e intentan que el trabajo de profesionales de desarrollo y operaciones fluya adecuadamente dando respuesta a las necesidades de software de las organizaciones hoy en día.
Los departamentos de Tecnologías de la Información (TI) de las organizaciones son responsables de responder con rapidez a los cambios del software, cambios muy necesarios en un mundo cómo el actual muy competitivo y proporcionar servicios seguros, estables y de confianza a los clientes.
Según “DevOps Handbook” de Gene Kim y Jez Humble en TI se produce una espiral de destrucción debido a que: primero los profesionales de operaciones están intentando mantener estables sistemas cuya infraestructura es compleja,  frágil y en muchos casos está mal documentada, segundo alguien en la organización (marketing, comercial, …) promete grandes funcionalidades que harán las delicias de los clientes y que van a estar disponibles para ya, tercero todo esto encamina a que las cosas cada vez sean más difíciles, cada profesional de desarrollo y operaciones esté cada vez más ocupado, el trabajo se desestructure, se vuelva todo más complicado y cómo consecuencia la comunicación se vuelve más lenta y la cantidad de trabajo pendiente se vuelve cada vez más grande. Y todo esto empeora y empeora con el paso del tiempo.

Para romper esta espiral, es necesario disponer de medios que permitan dotar de robustez a los sistemas complejos y buscar flujo de trabajo en el ambiente de desarrollo. Esto hará que los profesionales de TI estén entregados a un trabajo en el que el sobreesfuerzo y la heroicidad no tengan que ser una constante, es decir un entorno normalmente “amable” de trabajo.

Existen evidencias de que usar prácticas recomendadas por DevOps mejora la construcción y puesta en marcha del software. Una de ellas es el informe “State of DevOps Report” que llevan publicando Jez Humble y Gene Kim desde 2013 anualmente (https://puppet.com/resources/whitepaper/state-of-devops-report ). En las conclusiones del informe de 2018 dice:
Cada año, el State of DevOps report nos enseña algo nuevo. Este año nuestros datos han mostrado que mientras hay muchos caminos individuales de realizar una transformación DevOps, hay formas más rápidas de llegar al éxito. Las organizaciones pueden elegir entre ser sistemáticas en cuanto a cómo evolucionan o pueden adoptar una aproximación más particularizada. Por supuesto, es posible que una aproximación particular funcione, pero lo que vemos entre las organizaciones que han alcanzado los niveles más altos de evolución en DevOps, es que no llegaron ahí por casualidad.
Estamos encantados de ser capaces de proporcionar algo concreto y útil a los equipos que están trabajando duro para mejorar la forma en que trabajan……
Tener en cuenta las prácticas DevOps es crítico para que las organizaciones lidien con la confrontación de intereses entre profesionales de desarrollo y operaciones. Mientras esto no se consiga, los logros de TI serán muy dolorosos y como consecuencia esto hará que las organizaciones que no adopten prácticas DevOps sean cada vez menos competitivas.