官术网_书友最值得收藏!

Persistent storage

As you remember from Chapter 1, Introduction to Docker, the Docker container filesystem is kind of temporary by default. If you start up a Docker image (that is, run the container), you'll end up with a read-write layer on top of the layers stack. You can create, modify, and delete files as you wish; if you commit the changes back into the image, they will become persisted. This is a great feature if you want to create a complete setup of your application in the image, altogether with all its environment. But, this is not very convenient when it comes to storing and retrieving data. The best option would be to separate the container life cycle and your application from the data. Ideally, you would probably want to keep these separate, so that the data generated (or being used) by your application is not destroyed or tied to the container life cycle and can thus be reused.

The perfect example would be a web application server: the Docker image contains web server software, the same as Tomcat for example, with your Java application deployed, configured, and ready to use. But, the data the server will be using should be separated from the image. This is done via volumes, which we will focus on in this part of the chapter. Volumes are not part of the union filesystem, and so the write operations are instant and as fast as possible, there is no need to commit any changes.

Volumes live outside of the union filesystem and exist as normal directories and files on the host filesystem.

There are three main use cases for Docker data volumes:

  • To share data between the host filesystem and the Docker container
  • To keep data when a container is removed
  • To share data with other Docker containers

Let's begin with a list of volume-related commands at our disposal.

主站蜘蛛池模板: 社会| 姜堰市| 定边县| 旺苍县| 深水埗区| 忻州市| 四子王旗| 东港市| 两当县| 垫江县| 张家界市| 阳谷县| 昌黎县| 甘泉县| 垦利县| 芷江| 内丘县| 蕉岭县| 突泉县| 沾化县| 临颍县| 新竹市| 巩留县| 宿松县| 龙游县| 布拖县| 珲春市| 水城县| 米脂县| 蒲江县| 三亚市| 壤塘县| 福建省| 察隅县| 蒙山县| 惠东县| 久治县| 会同县| 巴南区| 凤凰县| 大姚县|