In docker, volume means "data volume", which can bypass the default joint file system and exist on the host in the form of a normal file or directory, thereby realizing the saving and sharing of persistent data. data between containers.
The operating environment of this tutorial: linux7.3 system, docker-1.13.1 version, Dell G3 computer.
What does volume mean in docker?
Docker Volume, usually translated as data volume, is used to save persistent data. When we run a database such as MySQL in a Docker container, we generally save the data on the host through Docker Volume. In this way, even if the MySQL container is deleted, the data is still saved on the host, effectively ensuring data security.
1. Specify Docker Volume
Use the docker run command to run a Docker container
docker run -itd --volume /tmp/data1:/tmp/data2 --name test ubuntu bash
Created based on the ubuntu image Create a Docker container.
The name of the container is test, specified by the –name option.
Docker Volume is specified by the –volume option. The /tmp/data1 directory of the host corresponds to the /tmp/data2 directory in the container one-to-one.
2. View Docker Volume
Use the docker inspect command to view the detailed information of the Docker container:
docker inspect --format= '{{json .Mounts}}' test | python -m json.tool [ { "Destination": "/tmp/data2", "Mode": "", "Propagation": "", "RW": true, "Source": "/tmp/data1", "Type": "bind" } ]
Use the –format option to selectively view the required container information. .Mount is the Docker Volume information of the container.
python -m json.tool can format and display the output json string.
Source represents the directory on the host, that is, /tmp/data1.
Destination is the directory in the container, which is /tmp/data2.
3. Local files can be synchronized to the container
Create a new hello.txt file in the local/tmp/data1 directory
touch /tmp/data1/hello.txt ls /tmp/data1/ hello.txt
hello.txt file is visible in the container/tmp/data2/ directory
Use the docker exec command to execute commands in the container.
docker exec test ls /tmp/data2/ hello.txt
It can be seen that modifications in the local directory /tmp/data1/ can be synchronized to the container directory /tmp/data2/.
4. Container files can be synchronized to the host
Create a new world.txt file in the container/tmp/data2 directory
docker exec test touch /tmp/data2/world.txt docker exec test ls /tmp/data2/ hello.txt world.txt
world.txt file Visible in the host/tmp/data1/ directory
ls /tmp/data1/ hello.txt world.txt
It can be seen that modifications in the container directory/tmp/data2/ can be synchronized to the host directory/tmp/data1/.
5. Conclusion
Docker Volume is essentially a directory or file shared between the container and the host, so that the data in the Docker Volume can be shared between the host and the container in real time Synchronize. When using Virtualbox to create a virtual machine, you can also configure a shared directory, which is very similar to Docker Volume.
Recommended learning: "docker video tutorial"
The above is the detailed content of What does volume mean in docker?. For more information, please follow other related articles on the PHP Chinese website!

The core concept of Docker architecture is containers and mirrors: 1. Mirrors are the blueprint of containers, including applications and their dependencies. 2. Containers are running instances of images and are created based on images. 3. The mirror consists of multiple read-only layers, and the writable layer is added when the container is running. 4. Implement resource isolation and management through Linux namespace and control groups.

Docker simplifies the construction, deployment and operation of applications through containerization technology. 1) Docker is an open source platform that uses container technology to package applications and their dependencies to ensure cross-environment consistency. 2) Mirrors and containers are the core of Docker. The mirror is the executable package of the application and the container is the running instance of the image. 3) Basic usage of Docker is like running an Nginx server, and advanced usage is like using DockerCompose to manage multi-container applications. 4) Common errors include image download failure and container startup failure, and debugging skills include viewing logs and checking ports. 5) Performance optimization and best practices include mirror optimization, resource management and security improvement.

The steps to deploy containerized applications using Kubernetes and Docker include: 1. Build a Docker image, define the application image using Dockerfile and push it to DockerHub. 2. Create Deployment and Service in Kubernetes to manage and expose applications. 3. Use HorizontalPodAutoscaler to achieve dynamic scaling. 4. Debug common problems through kubectl command. 5. Optimize performance, define resource limitations and requests, and manage configurations using Helm.

Docker is an open source platform for developing, packaging and running applications, and through containerization technology, solving the consistency of applications in different environments. 1. Build the image: Define the application environment and dependencies through the Dockerfile and build it using the dockerbuild command. 2. Run the container: Use the dockerrun command to start the container from the mirror. 3. Manage containers: manage container life cycle through dockerps, dockerstop, dockerrm and other commands.

How to build portable applications with Docker and Linux? First, use Dockerfile to containerize the application, and then manage and deploy the container in a Linux environment. 1) Write a Dockerfile and package the application and its dependencies into a mirror. 2) Build and run containers on Linux using dockerbuild and dockerrun commands. 3) Manage multi-container applications through DockerCompose and define service dependencies. 4) Optimize the image size and resource configuration, enhance security, and improve application performance and portability.

Docker and Kubernetes improve application deployment and management efficiency through container orchestration. 1.Docker builds images through Dockerfile and runs containers to ensure application consistency. 2. Kubernetes manages containers through Pod, Deployment and Service to achieve automated deployment and expansion.

Docker and Kubernetes are leaders in containerization and orchestration. Docker focuses on container lifecycle management and is suitable for small projects; Kubernetes is good at container orchestration and is suitable for large-scale production environments. The combination of the two can improve development and deployment efficiency.

Docker and Linux are perfect matches because they can simplify the development and deployment of applications. 1) Docker uses Linux's namespaces and cgroups to implement container isolation and resource management. 2) Docker containers are more efficient than virtual machines, have faster startup speeds, and the mirrored hierarchical structure is easy to build and distribute. 3) On Linux, the installation and use of Docker is very simple, with only a few commands. 4) Through DockerCompose, you can easily manage and deploy multi-container applications.


Hot AI Tools

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

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

Undress AI Tool
Undress images for free

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

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

SublimeText3 Linux new version
SublimeText3 Linux latest version

MinGW - Minimalist GNU for Windows
This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

DVWA
Damn Vulnerable Web App (DVWA) is a PHP/MySQL web application that is very vulnerable. Its main goals are to be an aid for security professionals to test their skills and tools in a legal environment, to help web developers better understand the process of securing web applications, and to help teachers/students teach/learn in a classroom environment Web application security. The goal of DVWA is to practice some of the most common web vulnerabilities through a simple and straightforward interface, with varying degrees of difficulty. Please note that this software

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.
