创建和使用桥接网络

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. MySQL学习笔记-多表查询(下)

    多表查询(下) 一. 联合查询 联合查询:将多次查询结果合并,形成新的查询结果集 select {字段列表} from {表A} ... union [all] select {字段列表} from ...

  2. 状态管理(redux)

    https://www.redux.org.cn/ 2013年 Facebook 提出了 Flux 架构的思想,引发了很多的实现.2015年,Redux 出现,将 Flux 与函数式编程结合一起,很短 ...

  3. C#.NET 国密 SM2 公钥证书从文本转换

    先前的 Util 是直接从文件中转换的 https://www.cnblogs.com/runliuv/p/15079404.html public static AsymmetricKeyParam ...

  4. 点击li 该li变色

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  5. 开源一款功能强大的 .NET 消息队列通讯模型框架 Maomi.MQ

    目录 文档说明 导读 快速开始 消息发布者 IMessagePublisher 连接池 消息过期 事务 发送方确认模式 独占模式 消费者 消费者模式 事件模式 分组 消费者模式 消费.重试和补偿 消费 ...

  6. CS后门源码特征分析与IDS入侵检测

    CS后门源码特征分析与IDS入侵检测考核作业 上线x64 getshell 抓心跳包,对特征字符解密Uqd3 用java的checksum8算法得到93,说明是x64的木马 public class ...

  7. linux查看redis安装路径

    ## linux查看redis安装路径 redis-cli -h 127.0.0.1 -p 6379redis-cli monitor > redis2.log /usr/local/redis ...

  8. VScode连接服务器不用每次都输入密码

    VScode连接服务器不用每次都输入密码. 用git或xcode的ssh keygen生成一组不带密码的 rsa2048 的公钥id_rsa_nopasswd.pub和私钥id_rsa_nopassw ...

  9. SpringBoot动态数据源配置

    SpringBoot动态数据源配置 序:数据源动态切换流程图如下: 1:pom.xml文件依赖声明 <dependency>   <groupId>org.springfram ...

  10. 前端 Array.sort() 源码学习

    源码地址 V8源码Array 710行开始为sort()相关 Array.sort()方法是那种排序呢? 去看源码主要是源于这个问题 // In-place QuickSort algorithm. ...