Docker --volume(数据持久化)

数据卷 volume

数据卷 是一个可供一个或多个容器使用的特殊目录,实现让容器中的一个目录和宿主机中的一个文件或者目录进行绑定。数据卷 是被设计用来持久化数据的

第一种:bind mount volume

第一步:创建本地目录

╭─root@du-z  
╰─➤  mkdir  /webroom
╭─root@du-z ~  
╰─➤  echo "123" > /webroom/index.html

第二步:绑定本地目录,运行容器

docker run -v    # 绑定一个数据卷 Bind mount a volume
╭─root@du-z ~  
╰─➤  docker run -v /webroom:/usr/share/nginx/html -d -P nginx
╭─root@du-z ~  
╰─➤  docker ps -q
553d7e454376

第三步:查看bind 和ip

╭─root@du-z /webroom  
╰─➤  docker inspect 553d7e454376|grep "Mounts" -A7
        "Mounts": [
            {
                "Type": "bind",
                "Source": "/webroom",
                "Destination": "/usr/share/nginx/html",
                "Mode": "",
                "RW": true,
                "Propagation": "rprivate"
╭─root@du-z /webroom  
╰─➤  docker inspect 553d7e454376|grep IPAddress       
            "SecondaryIPAddresses": null,
            "IPAddress": "172.17.0.3",
                    "IPAddress": "172.17.0.3",

第四步:验证

╭─root@du-z ~  
╰─➤  curl 172.17.0.3                            
123

第二种:Docker Management Volume

第一步:启动容器

╭─root@du-z ~  
╰─➤  docker run -v /usr/share/nginx/html -d -P nginx

╭─root@du-z ~  
╰─➤  docker ps -q
acc5955cc2db

第二步:查看mounts

╭─root@du-z ~  
╰─➤  docker inspect acc5955cc2db |grep "Mounts" -A7
        "Mounts": [
            {
                "Type": "volume",
                "Name": "8e9f40b822fff53819401c0dc2df116f732c0a60e839433d3de61d03fd84ebda",
                "Source": "/var/lib/docker/volumes/8e9f40b822fff53819401c0dc2df116f732c0a60e839433d3de61d03fd84ebda/_data",
                "Destination": "/usr/share/nginx/html",
                "Driver": "local",
                "Mode": "",

第三步:查看本机目录

╭─root@du-z ~  
╰─➤  ls  /var/lib/docker/volumes
8e9f40b822fff53819401c0dc2df116f732c0a60e839433d3de61d03fd84ebda

第四步:删除容器

╭─root@du-z ~  
╰─➤  docker stop acc5955cc2db
acc5955cc2db
╭─root@du-z ~  
╰─➤  docker rm -v  acc5955cc2db
acc5955cc2db

# 注意:在删除容器时可以rm -v 数据卷(volumes)也一起删除;

批量删除孤儿卷

docker volume rm $(docker volume ls -qf dangling=true)

# 被使用的卷不会被删除

第三种:Container Data (基于现有的容器)

第一步:先运行容器

╭─root@du-z ~  
╰─➤  docker run -d --name nginx1 nginx
18404c47804d194fe89dfc5b737ca0e508fa54db6cd5a05a62d98d414d763f07

第二步:再运行一个容器共享nginx1的volumes

╭─root@du-z ~  
╰─➤  docker run --volumes-from nginx1 -d nginx
387ea757f57e2d427ecca372b4048bc950ab5b4f24d0a8849f020e86c0079a7e

docker volume 命令

╭─root@du-z ~  
╰─➤  docker volume --help

Usage:	docker volume COMMAND

Manage volumes

Commands:
  create      Create a volume
  inspect     Display detailed information on one or more volumes
  ls          List volumes
  prune       Remove all unused local volumes
  rm          Remove one or more volumes

实例1:创建一个volume

╭─root@du-z ~  
╰─➤  docker volume create vol1
vol1
╭─root@du-z ~  
╰─➤  ls /var/lib/docker/volumes/
vol1

实例2:查看volumes列表

╭─root@du-z ~  
╰─➤  docker volume ls        
DRIVER              VOLUME NAME
local               vol1

实例3:查看volume的详细信息

╭─root@du-z ~  
╰─➤  docker volume inspect vol1
[
    {
        "CreatedAt": "2019-08-15T04:48:40-04:00",
        "Driver": "local",
        "Labels": {},
        "Mountpoint": "/var/lib/docker/volumes/vol1/_data",
        "Name": "vol1",
        "Options": {},
        "Scope": "local"
    }
]

实例4:批量删除volumes

docker volume rm $(docker volume ls -qf dangling=true)

# 被使用的卷不会被删除

posted @   du-z  阅读(1506)  评论(0编辑  收藏  举报
数据卷 volume第一种:bind mount volume第二种:Docker Management Volume第三种:Container Data (基于现有的容器)docker volume 命令
点击右上角即可分享
微信分享提示