What does volume mean in docker?
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!

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

AI Hentai Generator
Generate AI Hentai for free.

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

There are four ways to package a project in PyCharm: Package as a separate executable file: Export to EXE single file format. Packaged as an installer: Generate Setuptools Makefile and build. Package as a Docker image: specify an image name, adjust build options, and build. Package as a container: Specify the image to build, adjust runtime options, and start the container.

Overview LLaMA-3 (LargeLanguageModelMetaAI3) is a large-scale open source generative artificial intelligence model developed by Meta Company. It has no major changes in model structure compared with the previous generation LLaMA-2. The LLaMA-3 model is divided into different scale versions, including small, medium and large, to suit different application needs and computing resources. The parameter size of small models is 8B, the parameter size of medium models is 70B, and the parameter size of large models reaches 400B. However, during training, the goal is to achieve multi-modal and multi-language functionality, and the results are expected to be comparable to GPT4/GPT4V. Install OllamaOllama is an open source large language model (LL

Detailed explanation and installation guide for PiNetwork nodes This article will introduce the PiNetwork ecosystem in detail - Pi nodes, a key role in the PiNetwork ecosystem, and provide complete steps for installation and configuration. After the launch of the PiNetwork blockchain test network, Pi nodes have become an important part of many pioneers actively participating in the testing, preparing for the upcoming main network release. If you don’t know PiNetwork yet, please refer to what is Picoin? What is the price for listing? Pi usage, mining and security analysis. What is PiNetwork? The PiNetwork project started in 2019 and owns its exclusive cryptocurrency Pi Coin. The project aims to create a one that everyone can participate

Answer: PHP microservices are deployed with HelmCharts for agile development and containerized with DockerContainer for isolation and scalability. Detailed description: Use HelmCharts to automatically deploy PHP microservices to achieve agile development. Docker images allow for rapid iteration and version control of microservices. The DockerContainer standard isolates microservices, and Kubernetes manages the availability and scalability of the containers. Use Prometheus and Grafana to monitor microservice performance and health, and create alarms and automatic repair mechanisms.

There are many ways to install DeepSeek, including: compile from source (for experienced developers) using precompiled packages (for Windows users) using Docker containers (for most convenient, no need to worry about compatibility) No matter which method you choose, Please read the official documents carefully and prepare them fully to avoid unnecessary trouble.

PHP distributed system architecture achieves scalability, performance, and fault tolerance by distributing different components across network-connected machines. The architecture includes application servers, message queues, databases, caches, and load balancers. The steps for migrating PHP applications to a distributed architecture include: Identifying service boundaries Selecting a message queue system Adopting a microservices framework Deployment to container management Service discovery

Containerization improves Java function performance in the following ways: Resource isolation - ensuring an isolated computing environment and avoiding resource contention. Lightweight - takes up less system resources and improves runtime performance. Fast startup - reduces function execution delays. Consistency - Decouple applications and infrastructure to ensure consistent behavior across environments.

Deploy Java EE applications using Docker containers: Create a Dockerfile to define the image, build the image, run the container and map the port, and then access the application in the browser. Sample JavaEE application: REST API interacts with database, accessible on localhost after deployment via Docker.
