创建和使用桥接网络

docker network create  --driver bridge  --subnet 192.168.13.0/24  --gateway 192.168.13.1 mqynet

详情

[root@docker ~]# docker network inspect mqynet
[
{
"Name": "mqynet",
"Id": "412a5fcb7d5b08cf80f4bec33f258b572dfd7d37f36b325a9a6426eb6a7518cf",
"Created": "2022-04-20T19:11:51.020561175+08:00",
"Scope": "local",
"Driver": "bridge",
"EnableIPv6": false,
"IPAM": {
"Driver": "default",
"Options": {},
"Config": [
{
"Subnet": "192.168.13.0/24",
"Gateway": "192.168.13.1"
}
]
},
"Internal": false,
"Attachable": false,
"Ingress": false,
"ConfigFrom": {
"Network": ""
},
"ConfigOnly": false,
"Containers": {},
"Options": {},
"Labels": {}
}
]
[root@docker ~]#

创建四个容器使之相互ping通

docker run -dit --name alpine1 --network mqynet alpine ash
docker run -dit --name alpine2 --network mqynet alpine ash
docker run -dit --name alpine3 --network mqynet alpine ash
docker run -dit --name alpine4 --network mqynet alpine ash docker exec -it alpine1 ping alpine1
docker exec -it alpine1 ping alpine2
docker exec -it alpine1 ping alpine3
docker exec -it alpine1 ping alpine4

docker卷的使用

创建卷

[root@docker ~]# docker volume create supermqy
supermqy

查看卷

[root@docker ~]# docker volume inspect supermqy
[
{
"CreatedAt": "2022-05-04T16:10:26+08:00",
"Driver": "local",
"Labels": {},
"Mountpoint": "/var/lib/docker/volumes/supermqy/_data",
"Name": "supermqy",
"Options": {},
"Scope": "local"
}
]
[root@docker ~]# docker volume inspect supermqy --format '{{ .Mountpoint }} {{ .Name}}'
/var/lib/docker/volumes/supermqy/_data supermqy
[root@docker ~]#

挂载卷

docker run -dit --name mqytest --mount source=supermqy,destination=/world centos /bin/bash

查看卷是否挂载成功

docker inspect fc83217fe0b873f9d14010f8f7c6502d607e

[root@docker ~]#

            "Type": "volume",
"Name": "supermqy",
"Source": "/var/lib/docker/volumes/supermqy/_data",
"Destination": "/world",
"Driver": "local",
"Mode": "z",

先删容器再删卷

docker rm -f supermqy
docker volume rm fc83217fe0b873f9d14010f8f7c6502d607e

挂载主机目录

注:此实验中

--mount在目录不存在时会报错

-v 则会自动创建目录

一个更严谨一个更方便

docker run -dti --name mqydev --mount type=bind,source='/fox/target',target=/world centos

查看验证绑定

[root@docker fox]# docker inspect f68963bdf1ef63f3aec102a88919db --format='{{json .Mounts}}'
[{"Type":"bind","Source":"/fox/target","Destination":"/world","Mode":"","RW":true,"Propagation":"rprivate"}]
[root@docker fox]#

删除

docker rm -f mqydev

只读挂载

[root@docker fox]# docker run -dti --name mqydev --mount type=bind,source='/fox/target',target=/world,readonly centos
fa936c5bb9dca13217a35ed2c48c354e8ac90b1d6f58567e93aa326119e0af0c
[root@docker fox]# docker exec -ti mqydev /bin/bash
[root@fa936c5bb9dc /]#
[root@fa936c5bb9dc /]#
[root@fa936c5bb9dc /]# ls
bin etc lib lost+found mnt proc run srv tmp var
dev home lib64 media opt root sbin sys usr world
[root@fa936c5bb9dc /]# cd world/
[root@fa936c5bb9dc world]# ls
aaa
[root@fa936c5bb9dc world]# touch aa
touch: cannot touch 'aa': Read-only file system
[root@fa936c5bb9dc world]#

测试容器填充卷

挂载填充卷

[root@docker fox]#  docker run -d --name=mqynginx  --mount source=nginx-vol,destination=/usr/share/nginx/html nginx
5965571a15cf46a86bb08aed1af654255a3ccd708417ab5317f0cb3d28b29d82

查看该卷详情

[root@docker fox]# docker volume inspect nginx-vol
[
{
"CreatedAt": "2022-05-04T16:39:44+08:00",
"Driver": "local",
"Labels": null,
"Mountpoint": "/var/lib/docker/volumes/nginx-vol/_data",
"Name": "nginx-vol",
"Options": null,
"Scope": "local"
}
]
[root@docker fox]#

查看该卷所在的目录内容

[root@docker fox]# ls -l /var/lib/docker/volumes//nginx-vol/_data/
total 8
-rw-r--r--. 1 root root 497 Dec 28 23:28 50x.html
-rw-r--r--. 1 root root 615 Dec 28 23:28 index.html
[root@docker fox]#

容器里的目录映射到了主机里

启动另一个容器挂载该卷,以使用其中预先填充的内容

[root@docker fox]# docker run -dit --name mqytest3 --mount source=nginx-vol,destination=/world centos /bin/bash
1e2bd2ec6955fbf7f1dc79266355cd6042277f13224cc8236576853727a5d1a7
[root@docker fox]#

查看容器中的挂载目录

[root@docker fox]# docker exec -it  mqytest3  ls /world
50x.html index.html

删除卷和容器

[root@docker fox]# x
5965571a15cf
fa936c5bb9dc
[root@docker fox]# docker volume rm -f nginx-vol
nginx-vol
[root@docker fox]# x为函数 删除所有容器
x ()
{
docker rm -f $(docker ps -aq)
}
[root@docker fox]# declare

docker加速器

修改加速器:https://www.cnblogs.com/xiugeng/p/16043012.html#_label0_3

文件的遮盖挂载

[root@docker fox]# docker run -tid --name broken-test --mount type=bind,source=/tmp,target=/etc/yum.repos.d centos
39c3835b9d0d11bea9ce8605c995ce02697eeb8c83dedbae8239292ff37ccad4
[root@docker fox]#
[root@docker fox]#
[root@docker fox]# docker exec -it broken-test /bin/bash
[root@39c3835b9d0d /]#
[root@39c3835b9d0d /]#
[root@39c3835b9d0d /]#
[root@39c3835b9d0d /]# cd /etc/yum.repos.d/
[root@39c3835b9d0d yum.repos.d]# ls
vmware-root_704-2990744159 vmware-root_713-4290166671
[root@39c3835b9d0d yum.repos.d]# cd

容器里原来的文件被挂载文件遮盖,取消挂载则会出现

docker 容器挂载技术的更多相关文章

  1. Docker容器化技术(下)

    Docker容器化技术(下) 一.Dockerfile基础命令 1.1.FROM - 基于基准镜像 FROM centos #制作基准镜像(基于centos) FROM scratch #不依赖任何基 ...

  2. Docker容器化技术(上)

    目录 Docker容器化技术 一.介绍 二.Docker的发展 三.Docker安装 四.阿里云Docker镜像加速 五.Docker的基本概念 六.命令 七.Docker宿主机与容器通信 八.容器内 ...

  3. Docker 容器相关技术

    Docker 依赖的Linux内核特性 Namespaces 命名空间 Control groups (cgroups) 控制组 理解这两个特性,能够更好的帮助我们理解docker的资源分配和管理 N ...

  4. docker容器虚拟化技术

    简单来说,在Windows系统下安装各种运行环境的坑简直不要太多了(● ̄(エ) ̄●),并不仅限于docker.Nginx.PHP.Python等等,我会尽详细写出实际过程中遇到的各种各样的奇葩问题 1 ...

  5. 新一代Java程序员必学的Docker容器化技术基础篇

    Docker概述 **本人博客网站 **IT小神 www.itxiaoshen.com Docker文档官网 Docker是一个用于开发.发布和运行应用程序的开放平台.Docker使您能够将应用程序与 ...

  6. Docker容器化技术

    1. 初始Docker 1.1 Docker概念 Docker概念:Docker是一个开源的应用容器引擎 诞生于2013年初,基于Go实现,dotCloud公司出品(后改名为Docker Inc) D ...

  7. Docker容器挂载宿主目录的情形分析

    Docker容器启动的时候,如果要挂载宿主机的一个目录,可以用-v参数指定. 譬如我要启动一个centos容器,宿主机的/test目录挂载到容器的/soft目录,可通过以下方式指定: # docker ...

  8. docker 学习(七) docker 容器挂载

    1:docker的默认存放位置: $ sudo su # cd /var/lib/docker # ls -F containers/ graph/ repositories volumes/     ...

  9. Docker容器相关技术

    docker需要依赖的Linux内核特性:(1)Namespaces 命名空间PID(Process ID) 用来隔离进程NET(Network) 管理网络接口IPC(InterProcess com ...

  10. docker容器挂载docker.sock,在容器内部直接与docker守护进程通信进行接口调用

    一.docker container实现 1.docker容器启动时挂载docker.sock docker run -it -- 2.curl调用接口 curl -s --unix-socket / ...

随机推荐

  1. nginx四层负载nginx七层负载,nginx基于nginx-sticky会话保持.

    1. nginx负载均衡实战 nginx提供了 4 7层负载均衡. 可根据业务需求选择不同负载均衡策略. 1.1.1 nginx四层负载均衡[网络层TCP负载] 不支持动静分离,但支持 http my ...

  2. itest(爱测试)开源接口测试&敏捷测试管理平台8.1.0发布

    (一)itest 简介 itest 开源敏捷测试管理,testOps 践行者,极简的任务管理,测试管理,缺陷管理,测试环境管理,接口测试,接口Mock 6合1,又有丰富的统计分析.可按测试包分配测试用 ...

  3. 深入解读Prometheus Adapter:云原生监控的核心组件

    本文详述了Prometheus Adapter的部署与配置,通过三个实践案例展示其在Kubernetes环境中的应用,帮助用户实现基于自定义指标的自动扩展和跨集群统一监控. 关注作者,分享AI全维度知 ...

  4. v-for 伪标签:template:

    根据一组数组或对象的选项列表进行渲染. v-for指令需要使用 (item,index) in 数组或对象 形式的特殊语法,同时还需要指定key值,key的作用在vue进行新旧数据比对渲染页面里,如果 ...

  5. OOP第二阶段题集总结

    一.前言 知识点:考察继承和多态为多,其中还涉及迭代器的使用,在每个题集中都有一个综合性题目设计多方面知识点考试,有List类和HashMap的使用以及正则表达式的运用,并且注重考查设计,理解类与类之 ...

  6. springmvc组件说明

    DispatcherServlet:前端控制器,也称为中央控制器,它是整个请求响应的控制中心,组件的调用由它统一调度. HandlerMapping:处理器映射器,它根据用户访问的 URL 映射到对应 ...

  7. 高德的API来查询行政区域查询

    高德的API来查询行政区域查询 1.api接口文档地址 https://lbs.amap.com/api/webservice/guide/api/district GET https://resta ...

  8. Flash驱动控制--芯片擦除(SPI协议)

    摘要: 本篇博客具体包括SPI协议的基本原理.模式选择以及时序逻辑要求,采用FPGA(EPCE4),通过SPI通信协议,对flash(W25Q16BV)存储的固化程序进行芯片擦除操作. 关键词:SPI ...

  9. java datetime数据类型去掉时分秒

    在Java中,如果我们想要表示一个日期而不包括时间(时分秒),我们通常会使用java.time包中的LocalDate类.LocalDate是一个不可变的日期对象,它只包含年.月.日三个字段. 1. ...

  10. CSS 属性计算

    CSS 属性计算过程 你是否了解 CSS 的属性计算过程呢? 有的同学可能会讲,CSS属性我倒是知道,例如: p{ color : red; } 上面的 CSS 代码中,p 是元素选择器,color ...