Cómo poner 1 contraseña en GRUB: Seguridad avanzada

Cómo poner contraseña en GRUB

Cómo poner contraseña al gestor de arranque GRUB

El gestor de arranque GRUB (Grand Unified Bootloader) es uno de los más utilizados en sistemas Linux para gestionar el inicio del sistema operativo. Sin embargo, si no está protegido, cualquier persona con acceso físico al equipo podría modificar sus opciones de arranque, acceder al sistema en modo de recuperación o incluso cambiar la configuración del kernel. Por eso, establecer una contraseña en GRUB es una medida importante para proteger la integridad y seguridad de tu sistema.

contraseña en GRUB

¿Por qué proteger el gestor de arranque GRUB?

El gestor de arranque GRUB es la puerta de entrada al sistema operativo. Si alguien con acceso físico a tu equipo puede modificar los parámetros de arranque, podría iniciar el sistema en modo de recuperación, acceder a archivos protegidos o incluso dejar el sistema inoperativo. Al proteger GRUB con una contraseña en GRUB, reduces significativamente este riesgo y garantizas que solo usuarios autorizados puedan realizar cambios críticos en el arranque.

1. Generar la contraseña para GRUB

Lo primero que debemos hacer es generar una contraseña cifrada para GRUB. Abre una terminal y ejecuta el siguiente comando:

grub-mkpasswd-pbkdf2

Te pedirá que ingreses una contraseña y luego la confirmarás. Al final, te mostrará una salida similar a esta:

PBKDF2 hash of your password is grub.pbkdf2.sha512.10000.xxxxxxxxxxxxxxxxxx

Copia esta cadena, ya que la utilizaremos en el archivo de configuración de GRUB para establecer la contraseña en GRUB.

2. Editar el archivo de configuración de GRUB

Abre el archivo de configuración principal de GRUB con privilegios de superusuario:

sudo nano /etc/grub.d/40_custom

Añade las siguientes líneas al final del archivo:

set superusers="tu_usuario"
password_pbkdf2 tu_usuario grub.pbkdf2.sha512.10000.xxxxxxxxxxxxxxxxxx
  • Reemplaza tu_usuario por el nombre de usuario que desees utilizar.
  • Pega el hash de la contraseña generada anteriormente.

Estas líneas establecen un superusuario y su contraseña en GRUB para proteger el gestor de arranque.

3. Proteger entradas específicas del menú de GRUB

Si deseas proteger entradas específicas del menú de GRUB, puedes agregar --unrestricted para permitir opciones sin contraseña o dejarlo protegido por defecto. Por ejemplo:

menuentry "Modo de recuperación" {
    set superusers="tu_usuario"
    password_pbkdf2 tu_usuario grub.pbkdf2.sha512.10000.xxxxxxxxxxxxxxxxxx
}

Esto garantiza que solo el usuario autorizado pueda acceder a opciones críticas mediante su contraseña en GRUB.

4. Actualizar la configuración de GRUB

Una vez realizados los cambios, actualiza la configuración de GRUB para que se apliquen:

sudo update-grub

Este comando regenerará el archivo de configuración principal de GRUB.

5. Reiniciar el sistema

Reinicia tu equipo para verificar que la contraseña en GRUB funciona correctamente:

sudo reboot

En el menú de GRUB, intenta acceder a las opciones de edición (tecla e) y verifica que te solicita la contraseña.

Consejos adicionales para proteger GRUB

  • Desactiva el arranque desde dispositivos externos en la BIOS.
  • Configura una contraseña en la BIOS para evitar cambios en el orden de arranque.
  • Mantén el sistema actualizado para evitar vulnerabilidades.

Autor del Videotutorial Jan Herrera

Conclusión

Configurar una contraseña en GRUB es una medida de seguridad esencial que no debe pasarse por alto. Protege no solo la configuración del sistema, sino también el acceso no autorizado a funciones críticas. Siguiendo estos pasos, garantizarás que solo los usuarios autorizados puedan realizar cambios importantes en el arranque del sistema.

El gestor de arranque GRUB es una de las primeras líneas de defensa para tu sistema operativo. Sin una contraseña adecuada, cualquier persona con acceso físico al equipo podría modificar parámetros clave o incluso iniciar el sistema en modo de recuperación.

Establecer una contraseña no es complicado, pero requiere atención a los detalles. Asegúrate de elegir una clave robusta, combinando letras, números y caracteres especiales.

¡No olvides guardar bien tu contraseña en GRUB, ya que podría ser crucial para recuperar el sistema en caso de fallos! Si pierdes esta contraseña, podrías enfrentar dificultades significativas para acceder al sistema.

Además, recuerda que una buena práctica es revisar periódicamente la configuración de GRUB y actualizar la contraseña si sospechas que ha podido ser comprometida.

Si tienes alguna duda o problema, déjame un comentario y estaré encantado de ayudarte. ¡Proteger tu sistema nunca está de más!

Caso práctico para Docker

6 Éxitos garantizados: Caso práctico para Docker paso a paso

Docker se ha convertido en una herramienta esencial para desarrolladores y administradores de sistemas debido a su capacidad para simplificar el despliegue y la gestión de aplicaciones. Caso práctico para Docker: su potencial no está limitado a grandes empresas o proyectos complejos; también puede ser extremadamente útil en pequeños proyectos personales o para pymes.

🔗 ¿Qué es Docker y por qué usarlo?

Docker es una plataforma que permite crear, probar y desplegar aplicaciones en contenedores. Un contenedor es un paquete que incluye el código de una aplicación, sus bibliotecas y dependencias, garantizando que funcione de la misma manera en cualquier entorno.

Ventajas para pequeños proyectos:

  • Portabilidad: El mismo contenedor funciona igual en cualquier sistema.
  • Ahorro de recursos: Consume menos recursos que una máquina virtual.
  • Escalabilidad: Fácil de adaptar a medida que el proyecto crece.
  • Consistencia: El entorno de desarrollo y producción son idénticos, reduciendo errores inesperados.
  • Rapidez: Los contenedores se inician en cuestión de segundos.

💡 Caso práctico para Docker 1: Despliegue de un servidor web local

Objetivo: Configurar un servidor web Nginx en tu máquina local.

  1. Instala Docker en tu sistema.
  2. Crea un archivo docker-compose.yml:
    version: '3'
    services:
      web:
        image: nginx:latest
        ports:
          - "8080:80"
        volumes:
          - ./html:/usr/share/nginx/html
    
  3. Crea una carpeta llamada html y agrega un archivo index.html con contenido simple.
  4. Ejecuta el comando: docker-compose up -d
  5. Abre tu navegador y accede a http://localhost:8080.

Beneficios:

  • Desarrollo rápido sin necesidad de configuraciones complejas.
  • Entorno reproducible para cualquier colaborador del proyecto.

💡 Caso práctico para Docker 2: Base de datos MySQL para pruebas locales

Objetivo: Levantar una base de datos MySQL para pruebas.

  1. Crea otro archivo docker-compose.yml:
    version: '3'
    services:
      db:
        image: mysql:5.7
        environment:
          MYSQL_ROOT_PASSWORD: example
          MYSQL_DATABASE: testdb
          MYSQL_USER: user
          MYSQL_PASSWORD: userpass
        ports:
          - "3306:3306"
    
  2. Ejecuta docker-compose up -d.
  3. Conéctate usando un cliente MySQL con los datos especificados.

Beneficios:

  • Pruebas locales sin afectar bases de datos en producción.
  • Fácil integración con otras aplicaciones Docker.

💡 Caso práctico para Docker 3: Despliegue de una aplicación Node.js

Objetivo: Desplegar una aplicación básica de Node.js.

  1. Crea un archivo Dockerfile:
    FROM node:14
    WORKDIR /app
    COPY package*.json ./
    RUN npm install
    COPY . .
    CMD ["node", "app.js"]
    EXPOSE 3000
    
  2. Construye la imagen:
    docker build -t my-node-app .
    
  3. Ejecuta el contenedor:
    docker run -p 3000:3000 my-node-app
    
  4. Accede a http://localhost:3000.

Beneficios:

  • Despliegue consistente en cualquier entorno.
  • Rápida iteración y desarrollo.

💡 Caso práctico para Docker 4: Implementación de Redis para almacenamiento en caché

Objetivo: Configurar un servidor Redis para caché.

  1. Crea un archivo docker-compose.yml:
    version: '3'
    services:
      cache:
        image: redis:latest
        ports:
          - "6379:6379"
    
  2. Ejecuta docker-compose up -d.
  3. Conéctate usando un cliente Redis para verificar su funcionamiento.

Beneficios:

  • Mejora el rendimiento de aplicaciones al almacenar datos temporales.
  • Ideal para gestionar sesiones de usuario.

💡 Caso práctico para Docker 5: Servidor de Jenkins para integración continua

Objetivo: Configurar Jenkins para automatizar despliegues.

  1. Crea un archivo docker-compose.yml:
    version: '3'
    services:
      jenkins:
        image: jenkins/jenkins:lts
        ports:
          - "8081:8080"
          - "50000:50000"
    
  2. Ejecuta docker-compose up -d.
  3. Accede a Jenkins desde http://localhost:8081.

Beneficios:

  • Automatización de pruebas y despliegues.
  • Mayor eficiencia en flujos de trabajo.

💡 Caso práctico para Docker 6: Despliegue de una aplicación Python Flask

Objetivo: Crear una aplicación Flask en un contenedor.

  1. Crea un archivo Dockerfile:
    FROM python:3.9
    WORKDIR /app
    COPY . .
    RUN pip install flask
    CMD ["python", "app.py"]
    EXPOSE 5000
    
  2. Ejecuta
    docker build -t flask-app
  3. Ejecuta
    docker run -p 5000:5000 flask-app

Beneficios:

  • Entorno controlado para desarrollo.
  • Fácil despliegue en producción.

🔄 Recomendaciones finales

  • Usa Docker Desktop para una interfaz más amigable.
  • Mantén tus contenedores y dependencias actualizadas.

Caso práctico para Docker

Docker no solo es una herramienta poderosa, sino que también es increíblemente accesible para cualquier persona interesada en mejorar y optimizar sus flujos de trabajo. Con su capacidad para crear entornos aislados y replicables, Docker facilita la gestión de aplicaciones de manera eficiente, eliminando muchas de las complejidades que suelen surgir en el proceso de desarrollo. Ya sea que seas un principiante o un profesional experimentado, Docker Hub te ofrece la flexibilidad de trabajar de forma más ágil y efectiva.

¡Anímate a probar estos casos prácticos y empieza a experimentar con la creación y administración de contenedores! Lleva tus pequeños proyectos al siguiente nivel, mejora tu productividad y descubre cómo esta herramienta puede transformar tu manera de desarrollar, probar y desplegar aplicaciones.

¡Es el momento perfecto para adentrarte en el mundo de Docker y aprovechar sus múltiples ventajas!

>> tu Propia VPN con Pi-hole y WireGuard: 1 Guía Definitiva

Configura tu propia VPN con Pi-hole y WireGuard

¿Cansado de los anuncios intrusivos que interrumpen tu navegación y de los rastreadores que acechan cada uno de tus movimientos en línea? ¡No estás solo! La buena noticia es que existe una solución para disfrutar de una experiencia en internet más limpia, segura y privada: combinar Pi-hole y WireGuard.

¿Qué son Pi-hole y WireGuard?

  • Pi-hole: Es como un guardia de seguridad para tu conexión a internet. Bloquea los anuncios, rastreadores y otros elementos molestos antes de que lleguen a tu dispositivo. Funciona como un servidor DNS personalizado, interceptando tus solicitudes de DNS y filtrando el contenido no deseado.
  • WireGuard: Es un protocolo VPN moderno y rápido que crea un túnel seguro y encriptado entre tu dispositivo y un servidor. Esto significa que tu tráfico de internet está oculto y protegido de miradas indiscretas.

¿Por qué combinar ambos?

Al configurar tu propia VPN con Pi-hole y WireGuard con Docker obtienes lo mejor de ambos mundos:

  • Navegación sin anuncios: Pi-hole bloquea los anuncios de forma eficaz, haciendo que las páginas web carguen más rápido y sean más agradables a la vista.
  • Privacidad mejorada: WireGuard protege tu conexión, ocultando tu dirección IP y cifrando tus datos.
  • Acceso a contenido restringido: Puedes acceder a sitios web y servicios que están bloqueados en tu región.
  • Mayor seguridad: La VPN protege tu conexión de posibles ataques.

¿Cómo funciona tu propia VPN con Pi-hole y WireGuard en la práctica?

Imagina que tu casa es tu dispositivo y que tienes un guardia en la puerta (Pi-hole) que revisa a todos los visitantes (solicitudes de internet) antes de dejarlos entrar. Si alguien intenta entrar con malas intenciones (un anuncio), el guardia lo detiene. Además, tienes un túnel secreto (WireGuard) que te permite comunicarte con el mundo exterior de forma segura y privada.

¿Cómo configurar Pi-hole y WireGuard?

Configurar tu propio servidor Pi-hole y WireGuard puede parecer complicado al principio, pero hay muchos tutoriales y guías disponibles en línea para ayudarte. Necesitarás un dispositivo como una Raspberry Pi o un servidor VPS.

Beneficios de tener tu propia VPN con Pi-hole y WireGuard:

  • Personalización: Tú decides qué bloquear y cómo configurar tu VPN.
  • Ahorro de dinero: No necesitas pagar por servicios VPN comerciales.
  • Aprendizaje: Es una excelente manera de aprender sobre redes y seguridad.

Jose Web - Configura tu propia VPN con Pi-hole y WireGuard

¿Listo para empezar?

Si estás interesado en mejorar tu privacidad en línea y disfrutar de una experiencia de navegación más limpia, te recomiendo que explores las opciones de configurar tu propio servidor Pi-hole y WireGuard.

Como instalar en Docker con docker-compose.yml

services:
wg-easy:
environment:
# ⚠️ Change the server's hostname (clients will connect to):
- WG_HOST=ip fija o dominio duckdns.org

# ⚠️ Change the Web UI Password:
- PASSWORD_HASH=
$$2y$$10$$hBCoykrB95WSzuV4fafBzOHWKu9sbyVa34GJr8VV5R/pIelfEMYyG

# 💡 This is the Pi-Hole Container's IP Address
- WG_DEFAULT_DNS=10.8.1.3
- WG_DEFAULT_ADDRESS=10.8.0.x
image: ghcr.io/wg-easy/wg-easy:latest
container_name: wg-easy
volumes:
- ./.wg-easy:/etc/wireguard
ports:
- "51820:51820/udp"
- "51821:51821/tcp"
restart: unless-stopped
cap_add:
- NET_ADMIN
- SYS_MODULE
sysctls:
- net.ipv4.ip_forward=1
- net.ipv4.conf.all.src_valid_mark=1
networks:
wg-easy:
ipv4_address: 10.8.1.2

pihole:
image: pihole/pihole:latest
container_name: pihole
environment:
# ⚠️ Change the Web UI Password:
- WEBPASSWORD=xxxxx
volumes:
- './.pihole/etc-pihole:/etc/pihole'
- './.pihole/etc-dnsmasq.d:/etc/dnsmasq.d'
ports:
- "53:53/tcp"
- "53:53/udp"
- "5353:80/tcp"
restart: unless-stopped
networks:
wg-easy:
ipv4_address: 10.8.1.3

networks:
wg-easy:
ipam:
config:
- subnet: 10.8.1.0/24

Para generar un hash de contraseña bcrypt usando Docker, ejecute el siguiente comando:

docker run --rm -it ghcr.io/wg-easy/wg-easy wgpw 'Tu contraseña'

Al ejecutar el comando aparecerá una linea como esta:

PASSWORD_HASH=’$2b$12$coPqCsPtcFO.Ab99xylBNOW4.Iu7OOA2/ZIboHN6/oyxca3MWo7fW’ // literally YOUR_PASSWORD

Importante: tenga en cuenta que no escriba la contraseña hash generada entre comillas simples cuando utilice docker-compose.yml.

En su lugar, reemplace cada $ símbolo con dos $$ símbolos.

Por ejemplo:

PASSWORD_HASH=$$2y$$10$$hBCoykrB95WSzuV4fafBzOHWKu9sbyVa34GJr8VV5R/pIelfEMYyG

Este hash es para la contraseña ‘foobar123’, obtenida mediante el comando docker run ghcr.io/wg-easy/wg-easy wgpw 'foobar123'y luego insertada una adicional $antes de cada símbolo existente $. Finalmente ejecutamos el siguiente comando para crear el contendor y ejecutarlo:

docker-compose up -d

Videotutorial Como instalar tu propia VPN con Pi-hole y WireGuard en Docker en una Raspberry pi 5 con docker-compose.yml

Autor del Videotutorial DanieloTech

Tu Raspberry Pi 1 llave para tu propio reino digita

Tu Raspberry Pi 1 llave para tu propio reino digita

¿Qué son Docker y Raspberry Pi?

Imagina tener una pequeña computadora, como una Raspberry Pi, que pueda hacer prácticamente cualquier cosa que te propongas. Ahora, imagina que tienes una herramienta que te permite empaquetar aplicaciones y sus dependencias en contenedores aislados, llamados contenedores Docker. Al combinar estas dos tecnologías, obtienes una plataforma increíblemente versátil y potente para tus proyectos personales.

¿Qué es Docker?

Docker es una plataforma que te permite crear y gestionar contenedores. Estos contenedores son como pequeñas máquinas virtuales, pero mucho más ligeras y eficientes. Cada contenedor contiene una aplicación y todo lo que necesita para funcionar: código, bibliotecas, configuraciones, etc. Esto significa que puedes mover tus aplicaciones de un entorno a otro sin problemas.

¿Qué es Docker?

¿Qué es una Raspberry Pi?

La Raspberry Pi es una pequeña computadora de placa única, del tamaño de una tarjeta de crédito, que se ha vuelto muy popular en los últimos años. Es una plataforma ideal para aprender a programar, realizar proyectos de electrónica, crear servidores caseros y mucho más.

Raspberry Pi

¿Por qué combinar Docker con Raspberry Pi?

La combinación de Docker y Raspberry Pi ofrece numerosas ventajas:

  • Portabilidad: Puedes crear contenedores Docker en tu computadora y ejecutarlos en tu Raspberry Pi sin necesidad de realizar grandes cambios.
  • Aislamiento: Cada contenedor funciona de forma aislada, lo que evita conflictos entre diferentes aplicaciones.
  • Eficiencia: Los contenedores son más ligeros y eficientes que las máquinas virtuales tradicionales.
  • Escalabilidad: Puedes agregar o eliminar contenedores fácilmente para ajustar la capacidad de tu sistema.
  • Reproducibilidad: Puedes compartir tus contenedores con otros usuarios para que puedan reproducir tus proyectos fácilmente.

Usos personales de Docker y Raspberry Pi

Las posibilidades son casi infinitas. Aquí te presentamos algunos ejemplos:

  • Servidor web personal: Crea tu propio sitio web o blog.
  • Servidor de archivos: Almacena y comparte tus archivos en la nube.
  • Centro multimedia: Organiza y reproduce tu colección de películas, música y fotos.
  • Servidor de juegos: Juega a tus juegos favoritos con tus amigos en línea.
  • Laboratorio de desarrollo: Experimenta con diferentes lenguajes de programación y frameworks.
  • IoT: Crea dispositivos inteligentes y conectados.
  • Automatización del hogar: Controla luces, termostatos y otros dispositivos en tu hogar.
  • Robótica: Programa robots y vehículos autónomos.

Ejemplo práctico: un servidor web

  1. Crea un contenedor Docker con un servidor web: Utiliza una imagen de Docker preconstruida, como nginx o Apache.
  2. Configura el contenedor: Personaliza el servidor web según tus necesidades.
  3. Ejecuta el contenedor en tu Raspberry Pi: Inicia el contenedor y expón el puerto correspondiente para acceder al servidor web desde tu navegador.

¿Cómo empezar?

Instalar Docker y Docker Compose:

sudo curl -fsSL https://get.docker.com/ -o get-docker.sh
sudo sh get-docker.sh

-Añadir nuestro usuario al grupo Docker:

sudo usermod -aG docker ${USER}

-Reiniciar sistema:

sudo reboot

-Ejecutar un contenedor de prueba:

docker run hello-world

Portainer en Raspberry Pi

-Crear volumen Docker que contendrá los datos gestionados por el servidor Portainer:

docker volume create portainer_data

-Descargar e instalar contenedor Portainer:

docker run -d -p 8000:8000 -p 9443:9443 --name portainer --restart=always -v /var/run/docker.sock:/var/run/docker.sock -v portainer_data:/data portainer/portainer-ce:latest

-Ver contenedores instalados:

docker ps

-Acceso a Portainer:
https://[IP de tu Raspberry Pi]:9443
Ejemplo: https://192.168.1.10:9443

¿Qué es Docker?

¿Qué es Docker?

Imagina que tienes una receta de pastel. La receta contiene todos los ingredientes y los pasos exactos para hacer el pastel. Docker es como una receta, pero para software.

  • Imágenes de Docker: Son como las recetas. Contienen todas las instrucciones y dependencias necesarias para ejecutar una aplicación específica. Por ejemplo, una imagen puede contener un servidor web, una base de datos o una aplicación de Python.
  • Contenedores Docker: Son como los pasteles horneados a partir de la receta. Cuando ejecutas una imagen, creas un contenedor, que es una instancia en ejecución de esa aplicación. Cada contenedor es aislado y comparte el núcleo del sistema operativo del host, lo que los hace muy ligeros.

¿Para qué sirve y qué es Docker?

Docker ofrece numerosos beneficios tanto para desarrolladores como para equipos de operaciones:

  • Consistencia: Asegura que una aplicación se ejecute de la misma manera en cualquier entorno, ya sea tu computadora local, un servidor de desarrollo o la producción.
  • Portabilidad: Permite mover fácilmente aplicaciones entre diferentes sistemas operativos y arquitecturas de hardware.
  • Aislamiento: Cada contenedor es aislado, lo que evita conflictos entre aplicaciones y mejora la seguridad.
  • Eficiencia: Los contenedores son más ligeros que las máquinas virtuales, lo que los hace más rápidos y eficientes en términos de recursos.
  • Escalabilidad: Puedes crear y destruir contenedores rápidamente, lo que facilita la escalabilidad de tus aplicaciones.
  • Desarrollo ágil: Facilita la creación de entornos de desarrollo consistentes y reproducibles, acelerando el desarrollo de software.
  • Orquestación: Herramientas como Kubernetes permiten gestionar grandes cantidades de contenedores de forma automatizada.

En resumen, ¿Qué es Docker? es una plataforma que te permite crear, desplegar y gestionar aplicaciones de forma eficiente y consistente. Es una herramienta fundamental en el mundo de la DevOps y la nube, y se utiliza ampliamente en empresas de todos los tamaños.

¿Qué es Docker?

¿Quieres conocer algún ejemplo concreto de cómo qué es Docker en la práctica?

Algunos conceptos clave adicionales:

  • Imagen base: Es la imagen inicial sobre la que se construyen otras imágenes más específicas.
  • Dockerfile: Es un archivo de texto que contiene las instrucciones para construir una imagen.
  • Docker Hub: Es un registro público donde puedes encontrar y compartir imágenes de Docker.

Para un público técnico:

  • Docker es una plataforma de contenedores que permite empaquetar aplicaciones y sus dependencias en contenedores aislados y portables. Estos contenedores aseguran que las aplicaciones se ejecuten de forma consistente en cualquier entorno, simplificando el desarrollo, la implementación y la escalabilidad.
  • Docker ofrece una forma ligera de virtualización que permite ejecutar múltiples aplicaciones aisladas en un solo servidor, optimizando el uso de recursos.
  • Con Docker, puedes crear imágenes de contenedor que actúan como plantillas para tus aplicaciones. Estas imágenes se pueden compartir y almacenar en registros como Docker Hub.

Para un público menos técnico:

  • Imagina Docker como una caja donde puedes empacar todo lo que necesita tu aplicación para funcionar, desde el código hasta las librerías. Esta caja se puede mover y ejecutar en cualquier lugar sin problemas.
  • Docker simplifica la creación y el despliegue de aplicaciones al aislarlas en contenedores independientes. Esto hace que sea más fácil gestionar y escalar tus proyectos.
  • Con Docker, puedes asegurar que tu aplicación funcione de la misma manera en tu computadora, en un servidor de pruebas o en producción.

Para destacar los beneficios de Docker:

  • Mayor portabilidad: Ejecuta tus aplicaciones en cualquier lugar sin preocuparte por la configuración del sistema.
  • Mayor eficiencia: Utiliza los recursos del servidor de forma más eficiente al ejecutar múltiples aplicaciones en contenedores aislados.
  • Mayor escalabilidad: Aumenta o disminuye la cantidad de contenedores según la demanda de tu aplicación.
  • Mayor seguridad: Aislamiento de aplicaciones para mejorar la seguridad.
  • Desarrollo más rápido: Ciclos de desarrollo más cortos gracias a la facilidad de creación y despliegue de entornos.