From 2567f9f1a5fdfcaa6ac2a22ebaca93eb3113a212 Mon Sep 17 00:00:00 2001 From: Leandro Santiago Date: Sat, 25 Nov 2023 11:12:50 +0100 Subject: [PATCH] Dockerfile: Document exclude patterns on COPY and ADD commands Signed-off-by: Leandro Santiago --- frontend/dockerfile/docs/reference.md | 28 ++++++++++++++++++--------- 1 file changed, 19 insertions(+), 9 deletions(-) diff --git a/frontend/dockerfile/docs/reference.md b/frontend/dockerfile/docs/reference.md index 6d0447df750f4..3bb93dd7c83c6 100644 --- a/frontend/dockerfile/docs/reference.md +++ b/frontend/dockerfile/docs/reference.md @@ -1138,8 +1138,8 @@ RUN apt-get update && apt-get install -y ... ADD has two forms: ```dockerfile -ADD [--chown=:] [--chmod=] [--checksum=] ... -ADD [--chown=:] [--chmod=] ["",... ""] +ADD [--chown=:] [--chmod= [--exclude=]... [--checksum=] ... +ADD [--chown=:] [--chmod= [--exclude=]... ["",... ""] ``` The latter form is required for paths containing whitespace. @@ -1158,6 +1158,11 @@ The latter form is required for paths containing whitespace. > Only octal notation is currently supported. Non-octal support is tracked in > [moby/buildkit#1951](https://github.com/moby/buildkit/issues/1951). +> **Note** +> +> The `--exclude` option can be specified multiple times and cause files matching its patterns not to be copied, +> even if the files paths match the pattern specified in ``. + The `ADD` instruction copies new files, directories or remote file URLs from `` and adds them to the filesystem of the image at the path ``. @@ -1165,13 +1170,13 @@ Multiple `` resources may be specified but if they are files or directories, their paths are interpreted as relative to the source of the context of the build. -Each `` may contain wildcards and matching will be done using Go's +Each `` and `` may contain wildcards and matching will be done using Go's [filepath.Match](https://golang.org/pkg/path/filepath#Match) rules. For example: -To add all files starting with "hom": +To add all files starting with "hom", excluding all files with `txt` and `.md` extensions: ```dockerfile -ADD hom* /mydir/ +ADD --exclude=**/*.txt --exclude=**/*.md hom* /mydir/ ``` In the example below, `?` is replaced with any single character, e.g., "home.txt". @@ -1369,8 +1374,8 @@ See [`COPY --link`](#copy---link). COPY has two forms: ```dockerfile -COPY [--chown=:] [--chmod=] ... -COPY [--chown=:] [--chmod=] ["",... ""] +COPY [--chown=:] [--chmod=] [--exclude=]... ... +COPY [--chown=:] [--chmod=] [--exclude=]... ["",... ""] ``` This latter form is required for paths containing whitespace @@ -1383,6 +1388,11 @@ This latter form is required for paths containing whitespace > translating user and group names to IDs restricts this feature to only be viable for > Linux OS-based containers. +> **Note** +> +> The `--exclude` option can be specified multiple times and cause files matching its patterns not to be copied, +> even if the files paths match the pattern specified in ``. + The `COPY` instruction copies new files or directories from `` and adds them to the filesystem of the container at the path ``. @@ -1393,10 +1403,10 @@ of the build. Each `` may contain wildcards and matching will be done using Go's [filepath.Match](https://golang.org/pkg/path/filepath#Match) rules. For example: -To add all files starting with "hom": +To add all files starting with "hom", excluding all files with `txt` and `.md` extensions: ```dockerfile -COPY hom* /mydir/ +COPY --exclude=**/*.txt --exclude=**/*.md hom* /mydir/ ``` In the example below, `?` is replaced with any single character, e.g., "home.txt".