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

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.

主站蜘蛛池模板: 南开区| 台东县| 儋州市| 涟源市| 靖远县| 专栏| 辛集市| 焉耆| 剑川县| 海城市| 昆山市| 宣城市| 临邑县| 拜泉县| 文成县| 盘锦市| 蓬溪县| 台前县| 兰坪| 仪陇县| 塔河县| 咸宁市| 文成县| 红河县| 建阳市| 廊坊市| 阜康市| 云梦县| 山东| 喜德县| 外汇| 紫阳县| 海伦市| 辉县市| 吴忠市| 吉安县| 建湖县| 保靖县| 陆丰市| 贵港市| 华坪县|