The contents of the docker container image are created using personalized build artifacts and the configuration code which is copied from the build workspace during the docker build process, To achieve this purpose we use certain Docker DSL statements like ADD, COPY to dump the content to the docker image during the build process
It is good to throw some light into understanding the subtle differences between these statements.
It is important to send the up to date content to the Dockerfile and perform the build successfully, Lets see some practical case study of the Docker ADD vs COPY commands below:
| Docker  | Docker  | 
| Syntax: ADD </host/Relative/path/to/source/> <Container/image/path/to/Destination/> ADD [ "/host/path/source1/","/host/path/source2",.. "/container/path/target/" ] | Syntax: COPY </host/Relative/path/to/source/> <container/image/path/to/Destination/> COPY ["/host/path/source1/","/host/path/source2/",.. "/container/path/target/" ] | 
| ADD [source1,source2],,. /path/to/dest/ With multiple source files, the target container path must end with a  | COPY [source1,source2],,. /path/to/dest/ With multiple source files, the target container path must end with a  | 
| The Destination path inside container image can be Absolute or Relative to WORKDIR | The Destination path inside container image can be Absolute or Relative to WORKDIR | 
| The Destination path will be automatically created on target container with 0755 permissions | The Destination path will be automatically created on target container with 0755 permissions | 
| ADD default.conf /tmp/default.conf Creates the new files with the default 0644 permission | COPY default.conf /tmp/default.conf Creates the new files with the default 0644 permission | 
| The Destination content will be owned by the root user and the root group with uid & gid as 0 | The Destination content will be owned by the root user and the root group with uid & gid as 0 | 
| ADD directory /app | COPY directory /app | 
| ADD Directory Explanation: The whole directory will be copied from the source host to target container with directory permission as 0755 | COPY Directory Explanation: The whole directory will be copied from the source host to target container with directory permission as 0755 | 
| ADD Portal.tar.gz /tmp/portal1/ | COPY Portal.tar.gz /tmp/portal2/ | 
| Add Compressed file Explanation: The ADD command will extract the tar file and the extracted will be placed at the target container, with directory permissions as 0755 | COPY Compressed file Explanation: The COPY command will NOT extract the tar files and places them as it is.. at the destination target container path as a single compressed tar file. | 
| URL file as Source: ADD https://ftp.gnu.org/gnu/wget/wget-1.6.tar.gz.sig /tmp/test-add/ | URL file as Source – Not possible with COPY command Source can't be a URL for COPY | 
| ADD URL Explanation: With ADD the URL download and archive unpacking features cannot be used together Meaning it will be not extract the compressed tar.bz2 or tar.gz formats when it downloads from a URL inside the target container path. But it works just like RUN wget command and downloads the compressed package. | Explanation: COPY command will not be able treat source as a URL and Hence its not a valid command | 
Conclusion:
It is better to use ADD command if you have the source archive files like tar.gz, tar.bz2 and want to send them into your container image and extract them, ADD command does it automatically whilst the COPY command sends it as it is at source.
Both the ADD and COPY commands cannot access the source content which are outside of its current relative context path.
Eg:
ADD ../source-code /data
COPY ../source-code /data
You should always keep this in mind whilst writing Docker files.
Feel free to comment and share your experiences with the COPY / ADD commands.
Whats the difference between ADD and COPY Docker?
COPY only supports the basic copying of local files into the container, while ADD has some features (like local-only tar extraction and remote URL support) that are not immediately obvious. Consequently, the best use for ADD is local tar file auto-extraction into the image, as in ADD rootfs. tar.
What is the difference between COPY and add?
COPY copies a file/directory from your host to your image. ADD copies a file/directory from your host to your image, but can also fetch remote URLs, extract TAR files, etc
What is Docker add?
The ADD command is used to copy files/directories into a Docker image. It can copy data in three ways: Copy files from the local storage to a destination in the Docker image. Copy a tarball from the local storage and extract it automatically inside a destination in the Docker image.
What does COPY mean in Docker?
Dockerfiles can contain several different instructions, one of which is COPY. The COPY instruction lets us copy a file (or files) from the host system into the image. This means the files become a part of every container that is created from that image.
When should I use Docker COPY?
If you are copying local files to your Docker image, always use COPY because it’s more explicit. While functionality is similar, the ADD directive is more powerful in two ways: It can handle remote URLs. It can also auto-extract tar files.
Is Docker a recursive COPY?
Docker provides two commands for copying files from the host to the Docker image when building it: COPY and ADD . … COPY — copies local files recursively, given explicit source and destination files or directories.
Does Docker COPY overwrite?
It seems that docker build won’t overwrite a file it has previously copied. I have a dockerfile with several copy instructions, and files touched in earlier COPY directives don’t get overwritten by later ones.
How do I COPY a Docker container?
Solution
- To copy a file from the local file system to a container, run the command for Docker container or Kubernetes
- pod, respectively: docker cp <src-path> <container>:<dest-path> …
 To copy a file from the container to the local file system, use: docker cp <container>:<src-path> <local-dest-path>
Does Docker COPY create directory?
From the dockerfile reference about COPY and ADD , it says Note: The directory itself is not copied, just its contents. , so you have to specify a dest directory explicitly.
How do I copy a file in Dockerfile?
To do so follow the below steps:
- Step 1: Create a Directory to Copy. …
- Step 2: Edit the Dockerfile. …
- Step 3: Build the Docker Image. …
- Step 4: Verifying the Docker Image. …
- Step 5: Running the Docker Container. …
- Step 6: Verify the Copying of the Directory.
How does copy work in Dockerfile?
COPY and ADD are both Dockerfile instructions that serve similar purposes. They let you copy files from a specific location into a Docker image. COPY takes in a src and destination. It only lets you copy in a local file or directory from your host (the machine building the Docker image) into the Docker image itself.
What are Docker layers?
Basically, a layer, or image layer is a change on an image, or an intermediate image. Every command you specify ( FROM , RUN , COPY , etc.) in your Dockerfile causes the previous image to change, thus creating a new layer.
How do I copy a docker image?
To export your image to a tar file, run the docker save command, specifying a name for the . tar file, and the docker image name. This will save the docker image locally.