《Netkiller Virtualization 手札》Docker 卷管理

本文节选择《Netkiller Virtualization 手札》Docker 卷管理

1.5. 卷管理

1.5.1. 列出卷

docker volume ls

# docker volume ls
DRIVER              VOLUME NAME
local               dbac41b6de88c75d2932d5949367b17f347f482977d508195375dbc71518ab27			

1.5.2. 创建卷

# docker volume create --name WebVolume1
WebVolume1			
# docker volume ls
DRIVER              VOLUME NAME
local               WebVolume1
local               dbac41b6de88c75d2932d5949367b17f347f482977d508195375dbc71518ab27			

1.5.3. 挂在镜像

# docker run -ti --rm -v WebVolume1:/www ubuntu
# docker run -ti --rm -v WebVolume1:/www docker.io/centos:7			

查看卷的挂载情况

# df | grep /www
/dev/vda1       20510332 7943940  11501484  41% /www			

创建测试文件

			# mkdir -p /www/netkiller.cn/www.netkiller.cn
# echo Helloworld > /www/netkiller.cn/www.netkiller.cn/index.html
# cat /www/netkiller.cn/www.netkiller.cn/index.html
Helloworld
# exit
exit			

1.5.4. 检查卷

# docker volume inspect WebVolume1
[
    {
        "Driver": "local",
        "Labels": {},
        "Mountpoint": "/var/lib/docker/volumes/WebVolume1/_data",
        "Name": "WebVolume1",
        "Options": {},
        "Scope": "local"
    }
]			

1.5.5. 删除卷

# docker volume create AppVolume1
# docker volume rm AppVolume1			

1.5.6. 销毁所有未使用的卷

# docker volume prune
WARNING! This will remove all volumes not used by at least one container.
Are you sure you want to continue? [y/N] y
Deleted Volumes:
WebVolume1
3fd379f8c2cf8727d2e83e84e434ea1f122016957bd7cf78a0f05b6e5a69cf2b
app

Total reclaimed space: 11 B			

1.5.7. 在多个容器间共享卷

容器一

			# docker run -ti --name=Container1 -v DataVolume1:/opt/data ubuntu			

容器二

			# docker run -ti --name=Container2 --volumes-from Container1 ubuntu			

进入容器一中查看数据

			# docker start -ai Container1			

容器三,挂在只读卷

			# docker run -ti --name=Container3 --volumes-from Container2:ro ubuntu						

删除上面三个测试容易和卷

			# docker rm Container1 Container2 Container3
# docker volume rm DataVolume1			

1.5.8. 容器绑定本地文件系统

Bind mount a volume (default [])

			# docker run -it --name mycentos1 -v /www:/tmp/test docker.io/centos:7 /bin/bash

# docker run -d -v ~/logs:/var/log/nginx -p 80:80 -i nginx			

原文发布于微信公众号 - Netkiller(netkiller-ebook)

原文发表时间:2017-05-25

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏xcywt

Linux进程间通信之管道

1,进程间通信 (IPC ) Inter-Process Communication   比较好理解概念的就是进程间通信就是在不同进程之间传播或交换信息。 2,...

1888
来自专栏祝威廉

StreamingPro 简化流式计算配置

前些天可以让批处理的配置变得更优雅StreamingPro 支持多输入,多输出配置,现在流式计算也支持相同的配置方式了。

472
来自专栏博客园

Redis持久化方式

     snapsotting是默认方式,(把数据做一个备份,将数据存储在文件)

923
来自专栏行者悟空

Spark RDD的Action

1146
来自专栏运维前线

Docker三剑客

Docker集群管理工具 实验环境:CentOS 6.9 Docker Machine Docker Compose Docker Swarm Docke...

49710
来自专栏Java技术分享

Dubbo详细介绍与安装使用过程

1 Dubbo介绍 1.1 dubbox简介 随着互联网的发展,网站应用的规模不断扩大,常规的垂直应用架构已无法应对,分布式服务架构以及流动计算架构势在必行,亟...

2948
来自专栏乐沙弥的世界

MySQL多实例配置(二)

    MySQL数据库的集中化运维,可以通过在一台MySQL数据库服务器上,部署多个MySQL实例。该功能是通过mysqld_multi来实现。mysqld_...

842
来自专栏Laoqi's Linux运维专列

blocked for more than 120 seconds

1173
来自专栏大魏分享(微信公众号:david-share)

从开发角度看四类企业应用架构1: 通过Maven编译并运行一个Java应用

832
来自专栏java工会

Dubbo架构学习整理

随着互联网的发展和网站规模的扩大,系统架构也从单点的垂直结构往分布式服务架构演进,如下图所示:

680

扫描关注云+社区