容器挂载数据卷报错-初入docker日记篇

本文记录了在CentOS 7环境下使用Docker创建容器时,挂载数据卷失败的故障排查过程,重点在于iptables设置和daemon.json的影响,最终通过删除不必要配置解决了问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

docker的bug日记篇:

出了一个bug,就是xin麒想将要创建的容器在centos7挂载数据卷失败了。

一、案发现场:

[root@xinqi ~]# docker volume ls
DRIVER    VOLUME NAME
[root@xinqi ~]# docker images
REPOSITORY   TAG       IMAGE ID       CREATED         SIZE
nginx        latest    605c77e624dd   9 months ago    141MB
[root@xinqi ~]# docker volume create html
html
[root@xinqi ~]# docker volume inspect html
[
    {
        "CreatedAt": "2022-09-29T14:25:50+08:00",
        "Driver": "local",
        "Labels": {},
        "Mountpoint": "/var/lib/docker/volumes/html/_data",
        "Name": "html",
        "Options": {},
        "Scope": "local"
    }
]

xin麒欲想创建一个nginx容器,并且挂载容器重要文件到虚拟机/var/lib/docker/volumes/html/_data这个位置,但是出现了错误:

报错详情:

[root@xinqi ~]# docker run --name mynginx -p8080:80 -v html:/usr/share/nginx/html -d nginx
7fa8135461e5b45b188aa751ba4f3f4cc19c6f8d1bd5727bc6310264a35078c5
docker: Error response from daemon: driver failed programming external connectivity on endpoint mynginx (a887f75d26e23c07e5f430f4f6e008c72dc625bdff8c73573aef7947aa9fc40c):  (iptables failed: iptables --wait -t nat -A DOCKER -p tcp -d 0/0 --dport 8080 -j DNAT --to-destination 172.17.0.2:80 ! -i docker0: iptables: No chain/target/match by that name.
 (exit status 1)).
[root@xinqi ~]# docker ps
CONTAINER ID   IMAGE     COMMAND   CREATED   STATUS    PORTS     NAMES
[root@xinqi ~]# docker ps -a
CONTAINER ID   IMAGE     COMMAND                  CREATED          STATUS    PORTS     NAMES
7fa8135461e5   nginx     "/docker-entrypoint.…"   56 seconds ago   Created             mynginx

三、分析:

会不会是端口的原因,于是不断删除,不断尝试,发现还是一样的错误:

[root@xinqi ~]# docker rm -f mynginx 
mynginx
[root@xinqi ~]# docker run --name mynginx -p 8081:80 -v html:/usr/share/nginx/html -d nginx
909f32a0b18a545da420f5b78f6bff50174c364975d96c82da3c782b6fd978a0
docker: Error response from daemon: driver failed programming external connectivity on endpoint mynginx (166832793e07470df9fdc975615371832fec3891f688432d07c7b0084a197fae):  (iptables failed: iptables --wait -t nat -A DOCKER -p tcp -d 0/0 --dport 8081 -j DNAT --to-destination 172.17.0.2:80 ! -i docker0: iptables: No chain/target/match by that name.
 (exit status 1)).
[root@xinqi ~]# docker rm -f mynginx 
mynginx
[root@xinqi ~]# docker run --name mynginx -p 8081:8081 -v html:/usr/share/nginx/html -d nginx
4deaa2eec792807ad2a3d63ddb2d4076fd6e74fba2a71c4b2b5e6fbe85389f4f
docker: Error response from daemon: driver failed programming external connectivity on endpoint mynginx (ad6725e43997128df27857b3a0ba55759387e0d581cc4d36a45668784a4c3624):  (iptables failed: iptables --wait -t nat -A DOCKER -p tcp -d 0/0 --dport 8081 -j DNAT --to-destination 172.17.0.2:8081 ! -i docker0: iptables: No chain/target/match by that name.
 (exit status 1)).
[root@xinqi ~]# docker rm -f mynginx 
mynginx

然后又想到了会不会是之前的daemon.json旧的内容影响了当前的操作:

xin麒于是去查,又改了,终于才解决了

四、解决:

[root@xinqi _data]# cd /etc/docker
[root@xinqi docker]# ls
daemon.json  key.json
[root@xinqi docker]# cat daemon.json
{
  "registry-mirrors": ["https://************"],
  "insecure-registries": ["192.168.10.100:5000"]
}
[root@xinqi docker]# vim daemon.json 

将多余的"insecure-registries": ["192.168.10.100:5000"]删除

[root@xinqi docker]# cat daemon.json 
{
  "registry-mirrors": ["你自己的配置"]
}

五、成功+展示:

先将之前创建的nginx容器删除,再—>

[root@xinqi ~]# docker run --name mynginx -p 8080:8080 -v /var/lib/docker/volumes/html/_data:/usr/share/nginx/html -d nginx
ce3d891cfb88b431d8b8bb355ad932b1f32710d57c44ad778b04c1635467b241

xin麒想换为vomlue为html的数据卷来挂载:

于是

[root@xinqi docker]# docker rm -f mynginx 
mynginx
[root@xinqi ~]# docker run --name mynginx -p 8080:8080 -v html:/usr/share/nginx/html -d nginx
816f56974b1b8ef0d53f7db5c4f4a8dc12f67de470992ba335a11acbcfe536e9

查看一下:

[root@xinqi docker]# docker ps
CONTAINER ID   IMAGE     COMMAND                  CREATED          STATUS          PORTS                                               NAMES
816f56974b1b   nginx     "/docker-entrypoint.…"   19 minutes ago   Up 19 minutes   80/tcp, 0.0.0.0:8080->8080/tcp, :::8080->8080/tcp   mynginx

注意:如果nginx内部是使用80端口,那么可以改为80的端口。或者创建容器时用其他端口配置,而后再做对应的处理也行,这里便不做介绍。

[root@xinqi ~]# docker rm -f mynginx 
mynginx
[root@xinqi ~]# docker run --name mynginx -p 8080:80 -v /var/lib/docker/volumes/html/_data:/usr/share/nginx/html -d nginx
f985f9b425805f5dadba17f19bb2d01b97df44f6ad73a711fa0340b6911e2e32

end

<think>嗯,用户想了解如何在Docker中创建容器挂载数据卷。首先,我需要回忆Docker的基本命令,特别是docker run的用法。记得数据卷挂载有两种方式:具名挂载和匿名挂载,还有直接挂载主机目录。 用户可能需要具体的示例,所以得举几个例子。比如,挂载主机目录到容器,使用-v参数。比如docker run -v /宿主机路径:/容器路径。这时候要确保路径正确,特别是Windows和Linux的路径差异可能需要说明。 然后,具名挂载的例子,使用具名卷,比如创建一个名为my_volume的卷,然后挂载容器里。这时候可能要用到docker volume create命令,不过其实docker run的时候如果卷不存在会自动创建,所以可能不需要手动创建。需要提到docker volume inspect来查看卷的详细信息,这样用户知道如何检查挂载情况。 匿名挂载的话,只需要指定容器内的路径,宿主机路径由Docker自动生成,但可能不太方便管理,所以通常推荐具名挂载。不过还是应该提到,让用户了解区别。 另外,数据卷容器也是一个概念,可以通过--volumes-from来共享卷。比如创建一个数据卷容器,然后其他容器挂载它的卷。这个可能在多个容器需要共享数据时有用,比如备份或者多个服务访问同一数据。 用户可能还关心如何验证挂载是否成功,可以在容器内创建文件,然后在宿主机查看是否存在,或者用docker inspect命令查看挂载点。 还要注意权限问题,有时候容器内的用户可能没有写权限,导致挂载的目录不可写,这时候可能需要设置权限或者使用特权模式,但这里可能不需要深,除非用户提问。 安全问题方面,挂载主机目录可能会有风险,特别是挂载系统目录,需要提醒用户注意。 可能还需要提到数据卷的作用,比如持久化数据,避免容器删除后数据丢失,这样用户理解为什么需要挂载数据卷。 最后,给出具体的命令示例,分步骤说明,这样用户可以直接复制粘贴使用。同时,引用中的docker volume inspect和docker run命令需要对应上,确保示例准确。</think>### Docker 容器创建与数据卷挂载教程 #### 1. **基础命令格式** Docker 创建容器挂载数据卷的核心命令为: ```bash docker run -v [宿主机路径|卷名]:[容器路径] [其他参数] [镜像名] ``` 通过 `-v` 参数实现目录挂载,支持三种形式: - **主机目录挂载**:直接绑定宿主机目录 - **具名挂载**:使用预定义的数据卷名称 - **匿名挂载**:自动生成随机卷名 --- #### 2. **操作示例** **场景1:主机目录挂载** ```bash docker run -d --name nginx-web \ -v /home/user/nginx/html:/usr/share/nginx/html \ -p 80:80 \ nginx ``` - **验证挂载**: ```bash # 宿主机创建文件 touch /home/user/nginx/html/test.txt # 进容器检查 docker exec nginx-web ls /usr/share/nginx/html ``` **场景2:具名挂载** ```bash # 创建数据卷(可省略,Docker会自动创建) docker volume create app-data # 启动容器 docker run -d --name mysql-db \ -v app-data:/var/lib/mysql \ -e MYSQL_ROOT_PASSWORD=123456 \ mysql:8.0 ``` - **查看卷信息**: ```bash docker volume inspect app-data ``` 输出显示挂载点路径(如 `/var/lib/docker/volumes/app-data/_data`)[^1] **场景3:匿名挂载** ```bash docker run -d --name temp-storage \ -v /app/config \ alpine ``` - **查看匿名卷**: ```bash docker volume ls ``` --- #### 3. **数据卷容器共享** ```bash # 创建数据卷容器 docker create --name volume-container \ -v /shared-data \ busybox # 其他容器共享数据 docker run -d --name app1 \ --volumes-from volume-container \ nginx docker run -d --name app2 \ --volumes-from volume-container \ nginx ``` --- #### 4. **关键注意事项** 1. **路径规范**: - Windows 路径使用 `//C/Users` 格式 - 容器内路径需为绝对路径 2. **权限控制**: - 添加 `:ro` 限制容器只读(如 `-v data:/app:ro`) 3. **数据持久化**: - 容器删除后,具名/匿名卷会保留,需手动清理: ```bash docker volume rm [卷名] docker volume prune # 清理未使用卷 ``` ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值