He creado una imagen Docker a partir de un archivo Docker usando el siguiente comando.
$ docker build -t u12_core -f u12_core .
Cuando intento reconstruirlo con el mismo comando, está usando el caché de compilación como:
Step 1 : FROM ubuntu:12.04
---> eb965dfb09d2
Step 2 : MAINTAINER Pavan Gupta <[email protected]>
---> Using cache
---> 4354ccf9dcd8
Step 3 : RUN apt-get update
---> Using cache
---> bcbca2fcf204
Step 4 : RUN apt-get install -y openjdk-7-jdk
---> Using cache
---> 103f1a261d44
Step 5 : RUN apt-get install -y openssh-server
---> Using cache
---> dde41f8d0904
Step 6 : RUN apt-get install -y git-core
---> Using cache
---> 9be002f08b6a
Step 7 : RUN apt-get install -y build-essential
---> Using cache
---> a752fd73a698
Step 8 : RUN apt-get install -y logrotate
---> Using cache
---> 93bca09b509d
Step 9 : RUN apt-get install -y lsb-release
---> Using cache
---> fd4d10cf18bc
Step 10 : RUN mkdir /var/run/sshd
---> Using cache
---> 63b4ecc39ff0
Step 11 : RUN echo 'root:root' | chpasswd
---> Using cache
---> 9532e31518a6
Step 12 : RUN sed -i 's/PermitRootLogin without-password/PermitRootLogin yes/' /etc/ssh/sshd_config
---> Using cache
---> 47d1660bd544
Step 13 : RUN sed 's@session\s*required\s*pam_loginuid.so@session optional pam_loginuid.so@g' -i /etc/pam.d/sshd
---> Using cache
---> d1f97f1c52f7
Step 14 : RUN wget -O aerospike.tgz 'http://aerospike.com/download/server/latest/artifact/ubuntu12'
---> Using cache
---> bd7dde7a98b9
Step 15 : RUN tar -xvf aerospike.tgz
---> Using cache
---> 54adaa09921f
Step 16 : RUN dpkg -i aerospike-server-community-*/*.deb
---> Using cache
---> 11aba013eea5
Step 17 : EXPOSE 22 3000 3001 3002 3003
---> Using cache
---> e33aaa78a931
Step 18 : CMD /usr/sbin/sshd -D
---> Using cache
---> 25f5fe70fa84
Successfully built 25f5fe70fa84
El caché muestra que está instalado aerospike. Sin embargo, no lo encuentro dentro de los contenedores generados a partir de esta imagen, por lo que quiero reconstruir esta imagen sin usar el caché. ¿Cómo puedo forzar a Docker a reconstruir una imagen limpia sin el caché?
RUN
directivas.RUN
directiva, por lo que unaDockerfile
con muchasRUN
directivas consumiría enormes cantidades de espacio en disco; pero esto aparentemente ha mejorado algo en las versiones recientes.docker-compose up -d
, ¿dónde puedo usar--no-cache
?docker-compose build --no-cache
y luegodocker-compose up -d
Respuestas:
Hay una
--no-cache
opción:En versiones anteriores de Docker necesitabas pasar
--no-cache=true
, pero este ya no es el caso.fuente
--no-cache
funciona condocker-compose build
.--pull
. Esto le indicará a Docker que obtenga la última versión de la imagen base. Esto es necesario además de--no-cache
si ya tiene la imagen base (ej .ubuntu/latest
:) y la imagen base se ha actualizado desde la última vez que la sacó. Ver los documentos aquí .--pull
opción me sirvió. Simplemente--no-cache
, la construcción aún se rompió. Poner--pull
también, construir trabajado! ¡Gracias!En algunos casos extremos, su única forma de evitar fallas de compilación recurrentes es ejecutando:
El comando le pedirá su confirmación:
Por supuesto, esta no es una respuesta directa a la pregunta, pero podría salvar algunas vidas ... Salvó la mía.
fuente
Docker version 17.09.0-ce, build afdb6d4
docker
a la misma versión y funciona, gracias.docker builder prune
para borrar las capas de compilación en caché. Simplemente caí en la trampa después de copiar ciegamente los comandos del desbordamiento de la pila.El comando
docker build --no-cache .
resolvió nuestro problema similar.Nuestro Dockerfile fue:
Pero debería haber sido:
Para evitar el almacenamiento en caché de la actualización e instalar por separado.
Ver: Mejores prácticas para escribir Dockerfiles
fuente
RUN apt-get update && apt-get -y install php5-fpm
usted, todavía verá que se reutiliza con el contenido anterior.Para asegurarse de que su compilación se reconstruya por completo, incluida la comprobación de actualizaciones de la imagen base, use las siguientes opciones al compilar:
--no-cache
- Esto forzará la reconstrucción de capas ya disponibles--pull
- Esto activará una extracción de la imagen base a la que se hace referencia desde FROM, lo que garantiza que tenga la última versión.El comando completo se verá así:
Las mismas opciones están disponibles para docker-compose:
fuente
No recomendaría usar
--no-cache
en su caso.Está ejecutando un par de instalaciones desde el paso 3 al 9 (por cierto, preferiría usar un revestimiento) y si no desea la sobrecarga de volver a ejecutar estos pasos cada vez que construye su imagen, puede modifique su
Dockerfile
con un paso temporal antes de suwget
instrucción.Solía hacer algo así
RUN ls .
y cambiarlo aRUN ls ./
continuaciónRUN ls ./.
y así sucesivamente para cada modificación realizada en el tarball recuperado porwget
Por supuesto, puede hacer algo como
RUN echo 'test1' > test && rm test
aumentar el número'test1
para cada iteración.Parece sucio, pero que yo sepa, es la forma más eficiente de seguir beneficiándose del sistema de caché de Docker, que ahorra tiempo cuando tiene muchas capas ...
fuente
Con docker-compose intente
docker-compose up -d --build --force-recreate
fuente
La mayoría de la información aquí es correcta.
Aquí una recopilación de ellos y mi forma de usarlos.
La idea es apegarse al enfoque recomendado (compilación específica y sin impacto en otros objetos acoplados almacenados) e intentar el enfoque más radical (no compilar específico y con impacto en otros objetos acoplados almacenados) cuando no es suficiente.
Enfoque recomendado:
1) Forzar la ejecución de cada paso / instrucción en el Dockerfile:
o con
docker-compose build
:También podríamos combinar eso con el
up
subcomando que recrea todos los contenedores:De esta manera, no use caché sino para el generador de acopladores y la imagen base referenciada con el
FROM
instrucción.2) Limpie la memoria caché de Docker Builder (si usamos Buildkit, probablemente lo necesitemos):
3) Si no queremos usar el caché de las imágenes principales, podemos intentar eliminarlas como:
En la mayoría de los casos, estas 3 cosas son perfectamente suficientes para permitir una construcción limpia de nuestra imagen.
Entonces deberíamos tratar de mantenernos en eso.
Enfoque más radical:
En los casos de esquina donde parece que algunos objetos en la memoria caché del acoplador todavía se usan durante la compilación y eso parece repetible, debemos tratar de comprender la causa para poder borrar la parte faltante de manera muy específica. Si realmente no encontramos una manera de reconstruir desde cero, hay otras formas, pero es importante recordar que generalmente eliminan mucho más de lo necesario. Por lo tanto, debemos usarlos con precaución en general cuando no estamos en un entorno local / de desarrollo.
1) Eliminar todas las imágenes sin al menos un contenedor asociado a ellas:
2) Eliminar muchas cosas más:
Que dice :
El uso de ese comando súper eliminar puede no ser suficiente porque depende en gran medida del estado de los contenedores (en ejecución o no). Cuando ese comando no es suficiente, trato de pensar cuidadosamente qué contenedores acoplables pueden causar efectos secundarios en nuestra construcción de acopladores y permitir que estos contenedores salgan para permitir que se eliminen con el comando.
fuente
Puede administrar el caché del generador con
docker builder
Para limpiar todo el caché sin aviso:
docker builder prune -af
fuente