@ -12,7 +12,7 @@ For example: If you're looking for a `Node.js` image, you can search for "node"
To use a third-party image in your Dockerfile, simply set the image name as the base image using the `FROM` directive. Here's an example using the official Node.js image:
To use a third-party image in your Dockerfile, simply set the image name as the base image using the `FROM` directive. Here's an example using the official Node.js image:
@ -6,20 +6,20 @@ When building container images, it's essential to be aware of both image size an
- **Use an appropriate base image:** Choose a smaller, more lightweight base image that includes only the necessary components for your application. For example, consider using the `alpine` variant of an official image, if available, as it's typically much smaller in size.
- **Use an appropriate base image:** Choose a smaller, more lightweight base image that includes only the necessary components for your application. For example, consider using the `alpine` variant of an official image, if available, as it's typically much smaller in size.
```Dockerfile
```dockerfile
FROM node:14-alpine
FROM node:14-alpine
```
```
- **Run multiple commands in a single `RUN` statement:** Each `RUN` statement creates a new layer in the image, which contributes to the image size. Combine multiple commands into a single `RUN` statement using `&&` to minimize the number of layers and reduce the final image size.
- **Run multiple commands in a single `RUN` statement:** Each `RUN` statement creates a new layer in the image, which contributes to the image size. Combine multiple commands into a single `RUN` statement using `&&` to minimize the number of layers and reduce the final image size.
```Dockerfile
```dockerfile
RUN apt-get update && \
RUN apt-get update && \
apt-get install -y some-required-package
apt-get install -y some-required-package
```
```
- **Remove unnecessary files in the same layer:** When you install packages or add files during the image build process, remove temporary or unused files in the same layer to reduce the final image size.
- **Remove unnecessary files in the same layer:** When you install packages or add files during the image build process, remove temporary or unused files in the same layer to reduce the final image size.
```Dockerfile
```dockerfile
RUN apt-get update && \
RUN apt-get update && \
apt-get install -y some-required-package && \
apt-get install -y some-required-package && \
apt-get clean && \
apt-get clean && \
@ -28,7 +28,7 @@ When building container images, it's essential to be aware of both image size an
- **Use multi-stage builds:** Use multi-stage builds to create smaller images. Multi-stage builds allow you to use multiple `FROM` statements in your Dockerfile. Each `FROM` statement creates a new stage in the build process. You can copy files from one stage to another using the `COPY --from` statement.
- **Use multi-stage builds:** Use multi-stage builds to create smaller images. Multi-stage builds allow you to use multiple `FROM` statements in your Dockerfile. Each `FROM` statement creates a new stage in the build process. You can copy files from one stage to another using the `COPY --from` statement.
```Dockerfile
```dockerfile
FROM node:14-alpine AS build
FROM node:14-alpine AS build
WORKDIR /app
WORKDIR /app
COPY package*.json ./
COPY package*.json ./
@ -57,7 +57,7 @@ When building container images, it's essential to be aware of both image size an
- **Avoid running containers as root:** Always use a non-root user when running your containers to minimize potential risks. Create a user and switch to it before running your application.
- **Avoid running containers as root:** Always use a non-root user when running your containers to minimize potential risks. Create a user and switch to it before running your application.
```Dockerfile
```dockerfile
RUN addgroup -g 1000 appuser && \
RUN addgroup -g 1000 appuser && \
adduser -u 1000 -G appuser -D appuser
adduser -u 1000 -G appuser -D appuser
USER appuser
USER appuser
@ -65,7 +65,7 @@ When building container images, it's essential to be aware of both image size an
- **Limit the scope of `COPY` or `ADD` instructions:** Be specific about the files or directories you're copying into the container image. Avoid using `COPY . .` as it may unintentionally include sensitive files.
- **Limit the scope of `COPY` or `ADD` instructions:** Be specific about the files or directories you're copying into the container image. Avoid using `COPY . .` as it may unintentionally include sensitive files.
@ -6,7 +6,7 @@ Container images are executable packages that include everything required to run
The key component in building a container image is the `Dockerfile`. It is essentially a script containing instructions on how to assemble a Docker image. Each instruction in the Dockerfile creates a new layer in the image, making it easier to track changes and minimize the image size. Here's a simple example of a Dockerfile:
The key component in building a container image is the `Dockerfile`. It is essentially a script containing instructions on how to assemble a Docker image. Each instruction in the Dockerfile creates a new layer in the image, making it easier to track changes and minimize the image size. Here's a simple example of a Dockerfile:
```Dockerfile
```dockerfile
# Use an official Python runtime as a parent image
# Use an official Python runtime as a parent image