En este ejercicio vamos a volver a desplegar nuestra aplicación GuestBook, que realizamos en Actividad 5.3: Despliegue de la aplicación GuestBook y en la Actividad 6.1: Acceso de la aplicación GuestBook para añadirle persistencia a la base de datos redis.
Por lo tanto necesitaremos solicitar un volumen, que se asociará de forma dinámica.
Si estudiamos la documentación de la imagen redis en Docker Hub, para que la información de la base de datos se guarde en un directorio /data
del contenedor hay que ejecutar con docker:
docker run --name some-redis -d redis redis-server --appendonly yes
Es decir, hay que crear el contenedor ejecutando el proceso redis-server
con los argumentos --appendonly yes
.
Por lo tanto tenemos que cambiar el fichero de definición del Deployment de redis, redis-deployment.yaml
de la siguiente manera:
apiVersion: apps/v1
kind: Deployment
metadata:
name: redis
labels:
app: redis
tier: backend
spec:
replicas: 1
selector:
matchLabels:
app: redis
tier: backend
template:
metadata:
labels:
app: redis
tier: backend
spec:
volumes:
- name: volumen-redis
persistentVolumeClaim:
claimName: xxxxxxxxxxxx
containers:
- name: contenedor-redis
image: redis
command: ["redis-server"]
args: ["--appendonly", "yes"]
ports:
- name: redis-server
containerPort: 6379
volumeMounts:
- mountPath: xxxxxxxxxxxx
name: volumen-redis
Hemos usado el parámetro command
para ejecutar el proceso, y el parámetro args
para indicar los argumentos.
Nota: Los valores xxxxxxxxxxxx
tendrás que rellenarlos durante la realización de la actividad.
Realiza los siguientes pasos:
- Crea un fichero yaml para definir un recurso PersistentVolumenClaim que se llame
pvc-redis
y para solicitar un volumen de 3Gb. - Crea el recurso y comprueba que se ha asociado un volumen de forma dinámica a la solicitud.
- Modifica el fichero del despliegue de redis, modificando las
xxxxxxxxxxxx
por los valores correctos: el nombre del PersistentVolumenClaim y el directorio de montaje en el contenedor (como hemos visto anteriormente es/data
). - Crea el despliegue de redis. El despliegue de la aplicación
guestbook
y la creación de los Services de acceso se hace con los ficheros que ya utilizamos anteriormente:guestbook-deployment.yaml
,guestbook-srv.yaml
yredis-srv.yaml
. - Accede a la aplicación y escribe algunos mensajes.
- Comprobemos la persistencia: elimina el despliegue de redis, vuelve a crearlo, vuelve a acceder desde el navegador y comprueba que los mensajes no se han perdido.
Para superar la actividad deberás entregar en un fichero comprimido los siguientes pantallazos:
- Pantallazo con la definición del recurso PersistentVolumenClaim (pantallazo1.jpg).
- Pantallazo donde se visualicen los recursos
pv
ypvc
que se han creado (pantallazo2.jpg). - Pantallazo donde se vea el fichero yaml modificado para el despliegue de redis (pantallazo3.jpg).
- Pantallazo donde se vea el acceso a la aplicación con los mensajes escritos (pantallazo4.jpg).
- Pantallazo donde se vea que se ha eliminado y se ha vuelto a crear el despliegue de redis y que se sigue sirviendo la aplicación con los mensajes (pantallazo5.jpg).
- Conexión a internet
Si
Individual
Si
Si
No
No
- Se entregan los documentos, contienen lo solicitado y los contenidos son originales.
No
1 hora