推动安全服务行业的供给侧改革 鑫保险“更保险”
Check your current Docker version using docker --version to determine if an update is needed. 2. On Linux (Ubuntu/Debian), update via sudo apt update followed by sudo apt upgrade docker-ce docker-ce-cli containerd.io, or reinstall using sudo apt install docker-ce docker-ce-cli containerd.io if necessary, ensuring the official repository and GPG key are configured. 3. On macOS or Windows, open Docker Desktop, click the Docker icon, go to "Check for Updates", and follow the prompts to install the latest version, which includes the Engine, CLI, Compose, Kubernetes, and GUI tools. 4. If Docker was installed via Snap on Linux, run sudo snap refresh docker to update to the latest stable version, noting that Snap releases may lag behind official ones. 5. After updating, verify the installation with docker --version, docker info, and docker-compose --version if applicable. To maintain up-to-date systems, enable automatic updates using unattended-upgrades or schedule checks via cron or systemd, and always back up containers, volumes, and configurations before major updates to prevent data loss despite Docker’s stability.
Updating Docker depends on how you originally installed it and what operating system you're using. Here’s a clear guide for the most common scenarios.

1. Check Your Current Docker Version
Before updating, verify the installed version:
docker --version
This helps confirm whether an update is needed and what version you're coming from.

2. Update Docker on Linux (Ubuntu/Debian)
If you installed Docker using the official repository (recommended method), follow these steps:
? Update the package index and install the latest version:
sudo apt update sudo apt upgrade docker-ce docker-ce-cli containerd.io
This upgrades the Docker Engine, CLI, and containerd if updates are available.
? If no upgrade appears, you might need to reinstall:
sudo apt install docker-ce docker-ce-cli containered.io
This ensures you get the latest available version from the repo.
? Make sure you’ve added Docker’s official GPG key and repository. If not, follow Docker’s official install guide for Ubuntu/Debian.
3. Update Docker on macOS or Windows
Docker Desktop handles updates automatically in most cases.
? Manual update steps:
- Open Docker Desktop.
- Click on the Docker icon in the menu bar (macOS) or system tray (Windows).
- Go to "Check for Updates".
- If an update is available, click Update and restart when prompted.
Updates include Docker Engine, CLI, Compose, Kubernetes, and GUI tools.
4. Update Docker on Linux (using Snap)
If you installed Docker via Snap (less common):
sudo snap refresh docker
This automatically pulls the latest stable version.
?? Note: Snap versions may lag slightly behind official releases or use different configurations.
5. Verify the Update
After updating, confirm the new version:
docker --version docker info
Also check Docker Compose if you use it:
docker-compose --version
Bonus: Keep Docker Updated Automatically (Linux)
You can set up unattended upgrades for Docker:
sudo apt install unattended-upgrades
Then configure it to include Docker (if supported by your setup). Alternatively, use a cron job or systemd timer for manual checks.
Note: Always back up important containers, volumes, or configurations before major updates—even though Docker is stable, breaking changes can happen.
Basically, keep your package sources updated and use your system’s package manager unless you're on desktop, where Docker Desktop handles it for you.
The above is the detailed content of How to update Docker?. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undress AI Tool
Undress images for free

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

The main difference between Docker and traditional virtualization lies in the processing and resource usage of the operating system layer. 1. Docker containers share the host OS kernel, which is lighter, faster startup, and more resource efficiency; 2. Each instance of a traditional VM runs a full OS, occupying more space and resources; 3. The container usually starts in a few seconds, and the VM may take several minutes; 4. The container depends on namespace and cgroups to achieve isolation, while the VM obtains stronger isolation through hypervisor simulation hardware; 5. Docker has better portability, ensuring that applications run consistently in different environments, suitable for microservices and cloud environment deployment.

To back up and restore Docker volumes, you need to use temporary containers in conjunction with tar tools. 1. During backup, run a temporary container that mounts the target volume, use the tar command to package the data and save it to the host; 2. During recovery, copy the backup file to the container that mounts the volume and decompress it, pay attention to path matching and possible overwriting of data; 3. Multiple volumes can be written to automatically cycle through each volume; 4. It is recommended to operate when the container is stopped to ensure data consistency, and regularly test the recovery process to verify the backup validity.

To expose Docker container ports, the host needs to access the container service through port mapping. 1. Use the dockerrun-p[host_port]:[container_port] command to run the container, such as dockerrun-p8080:3000my-web-app; 2. Use the EXPOSE instruction to mark the purpose in the Dockerfile, such as EXPOSE3000, but the port will not be automatically published; 3. Configure the ports segment of the yml file in DockerCompose, such as ports:-"8080:3000"; 4. Use dockerps to check whether the port map is generated after running.

To view the metadata of the Docker image, the dockerinspect command is mainly used. 1. Execute dockerinspect to obtain complete metadata information, including ID, architecture, layer summary and configuration details; 2. Use Go templates to format the output, such as dockerinspect--format='{{.Os}}/{{.Architecture}}' to display only the operating system and architecture; 3. Use dockerhistory to view each layer of information during the image construction process to help optimize the image structure; 4. Use skopeo tool skopeoinspectdocker:///: to obtain without pulling the complete image.

Docker has three main volume types: namedvolumes, bindmounts, and tmpfsmounts. namedvolumes are managed by Docker and are suitable for scenarios where persistent data is required, such as databases; bindmounts map host-specific paths to containers, suitable for sharing code or configuration during development; tmpfsmounts stores data in memory, suitable for temporary or sensitive information. When using it, select the appropriate type according to your needs to optimize container data management.

To access services in Docker container from the host, use port mapping. The specific steps are: 1. Use -p to specify host_port:container_port when starting the container, such as dockerrun-d-p8080:80nginx; 2. Multiple ports can be configured through multiple -p parameters or DockerCompose files; 3. IP address binding can be limited, such as -p192.168.1.100:8080:80; 4. Use dockerps or dockerinspect to view port mapping details.

WhenchoosingbetweennamedvolumesandbindmountsinDocker,usenamedvolumesforcross-hostconsistency,reliabledatapersistence,andDocker-managedstorage,especiallyinproductionenvironments.①Namedvolumesautomaticallyhandlestoragepaths,ensuringportabilityacrossdev

Using lightweight basic images, merging and optimizing RUN instructions, and copying only necessary files are the key to reducing Docker images size. 1. Select lightweight basic images such as alpine, distroless or scratch to reduce unnecessary system components; 2. Merge multiple RUN commands and clean caches in time, such as combining apt-getupdate with installation commands, and delete /var/lib/apt/lists/*; 3. Exclude non-essential files through .dockerignore, use multi-stage construction to separate compilation and runtime dependencies, and copy only the necessary configuration and executable files into the final image. These methods can effectively reduce mirror size, improve construction and deployment efficiency, and reduce security
