实践环境

Centos7

Docker 20.10.5

问题描述

使用 docker-compose down 命令关闭容器时,提示类似以下错误:

Removing network xxx_default
ERROR: network xx_default id cec096539c911cc9c2f79a6e2152c9297c4f13778a05cce3f4beb85d78c02599 has active endpoints

解决方法

查看网络信息

# docker network ls
NETWORK ID NAME DRIVER SCOPE
3697abff8144 bridge bridge local
cec096539c91 testproject_default bridge local
43662a8e3234 host host local
9097274015ae none null local
# docker inspect testproject_default
[
{
"Name": "testproject_default",
"Id": "cec096539c911cc9c2f79a6e2152c9297c4f13778a05cce3f4beb85d78c02599",
"Created": "2021-03-09T12:38:18.283202946+08:00",
"Scope": "local",
"Driver": "bridge",
"EnableIPv6": false,
"IPAM": {
"Driver": "default",
"Options": null,
"Config": [
{
"Subnet": "172.20.0.0/16",
"Gateway": "172.20.0.1"
}
]
},
"Internal": false,
"Attachable": true,
"Ingress": false,
"ConfigFrom": {
"Network": ""
},
"ConfigOnly": false,
"Containers": {
"0aa99e2216c58639789efbc4078d4c0f0b185ae03a0f86b245fa8e43bed9e43c": {
"Name": "test_factory_automation_queue.celery",
"EndpointID": "bdb6a0f2d51591af4dc193f44ad436815b36db0085bde3c848067d6952985510",
"MacAddress": "02:42:ac:14:00:06",
"IPv4Address": "172.20.0.6/16",
"IPv6Address": ""
},
"35bd5e905655313950df7a7b28c57d2db0be7a3b1f409e38780e60f7561c0dbd": {
"Name": "be.api",
"EndpointID": "34ac5cbfac50b0da37d84d4b952f2edda572858248c1d9bb8b1beae47ce600bf",
"MacAddress": "02:42:ac:14:00:0f",
"IPv4Address": "172.20.0.15/16",
"IPv6Address": ""
},
"493e980856cc0a230dd03983421583dcbc54dc63af7b882f1f17c69e1b4d1ae2": {
"Name": "code_statistics_exec_queue.celery",
"EndpointID": "a3c96665fff6f1e2003be0ed094733bc1cc44012582672671642af56dec5b783",
"MacAddress": "02:42:ac:14:00:02",
"IPv4Address": "172.20.0.2/16",
"IPv6Address": ""
},
"4be82902bbef48a5997e6254543d3a6aba94b6eb0afc9c5bfa98c9e39437d886": {
"Name": "task.monitor",
"EndpointID": "05c7350beb5c52a0013119149f1075d9527dfd7c1e1775b0d50c84c76eca4466",
"MacAddress": "02:42:ac:14:00:05",
"IPv4Address": "172.20.0.5/16",
"IPv6Address": ""
},
"4eaf87b0571e3476d13daedbdf4492c4ef8df49939926d7397ce9431b83475b6": {
"Name": "be.beat",
"EndpointID": "bb3bc019b3338603bf07991822ae984c6ff5ecc2ddc9daf20e8d8196ea66f68b",
"MacAddress": "02:42:ac:14:00:07",
"IPv4Address": "172.20.0.7/16",
"IPv6Address": ""
},
"5377c1a27d4842878627e5c90f6abd4bcda0b2cb9a90ba2f09c31180cb59d3f7": {
"Name": "temporary_queue.celery",
"EndpointID": "eda6c7912ce0b96cd45de5a5b83cd3b8db36a0589da78d1f0b75feec43388b62",
"MacAddress": "02:42:ac:14:00:08",
"IPv4Address": "172.20.0.8/16",
"IPv6Address": ""
},
"6e50c145637a406665d6b4d1324c037cde63fac48e55f2a66051a94f06270c4b": {
"Name": "nginx",
"EndpointID": "cefe0ed43174c19b54aae4f0d0692d7dbf90fe547460d55a5f0634ba2c1d11f8",
"MacAddress": "02:42:ac:14:00:04",
"IPv4Address": "172.20.0.4/16",
"IPv6Address": ""
},
"8fac8fe4564f5248afe23cbf22c52404d1e15fdf6604b474bf7a913c0a5e5b79": {
"Name": "websocket_channel_queue.celery",
"EndpointID": "3de2141b43f42cc3697c7bcceef2f22638c8ae48b6ee4b2c9df5b2cab3a00f81",
"MacAddress": "02:42:ac:14:00:0d",
"IPv4Address": "172.20.0.13/16",
"IPv6Address": ""
},
"99ea28e93ba3022fd0b4462a11c1c9ae92e6ff25a9a3728b78885cdd1a9c6781": {
"Name": "ws.api",
"EndpointID": "ca3a4aadb97988b2536691dad6c15b949e33a043467579d57221fc5b2f7c477b",
"MacAddress": "02:42:ac:14:00:09",
"IPv4Address": "172.20.0.9/16",
"IPv6Address": ""
},
"aa37b2bc78170b39cc838011a70c8197b84faf76d5f9c25085b8de5b21cdd5cd": {
"Name": "mdm_pretreatedData_queue.celery",
"EndpointID": "48c9d9aaef14d18129d6f0946683173f0b75e86b80ad6c91699848454e7358c5",
"MacAddress": "02:42:ac:14:00:10",
"IPv4Address": "172.20.0.16/16",
"IPv6Address": ""
},
"ad4a3f803521329f0162f9d3c501b4a07e9f9347b1fcf93434fe0ec1f65b8186": {
"Name": "db.redis",
"EndpointID": "053492c8ece06a983e4ceeb2680def2aa47f2474ae093e8c8e3351bff48879af",
"MacAddress": "02:42:ac:14:00:0c",
"IPv4Address": "172.20.0.12/16",
"IPv6Address": ""
},
"ada7696d064713414d77b32c4fc991831bc6294a8c9c749024741fdac38ee2b2": {
"Name": "locust_case_exec_queue.celery",
"EndpointID": "298936d7adeabe2afcd8647ed0e7660b162e455552b4c54a724c15c2219266cf",
"MacAddress": "02:42:ac:14:00:03",
"IPv4Address": "172.20.0.3/16",
"IPv6Address": ""
},
"bdf4c37f7ab88014d8e493a146255d6a2ffde50580e3164276447923147895ea": {
"Name": "test_factory_common_queue.celery",
"EndpointID": "ebe85ebfa63c07cf085edfafe6de26bb1f137c9dfca2506c74b4787e2b5d1f4f",
"MacAddress": "02:42:ac:14:00:0e",
"IPv4Address": "172.20.0.14/16",
"IPv6Address": ""
},
"c93bfcb8ddbf66b996f3ba33ea9c8ae9bb4234001a9d7e5a708a3793876a8f31": {
"Name": "ct_test_exec_queue.celery",
"EndpointID": "6f267c19021416b9d03e6fe7b66bdfdd4524666f5c3e7d3ec0ae6d68a9647793",
"MacAddress": "02:42:ac:14:00:0b",
"IPv4Address": "172.20.0.11/16",
"IPv6Address": ""
},
"ef73c5728e840d69c04372044545a370262f4b438c312e9fa012b249977b1f67": {
"Name": "mdm_oe_trans_queue.celery",
"EndpointID": "48d8c2ed1413338e2b461ee8ef497fc951e914fe698fcad311bd03f53cefd7f3",
"MacAddress": "02:42:ac:14:00:0a",
"IPv4Address": "172.20.0.10/16",
"IPv6Address": ""
}
},
"Options": {},
"Labels": {
"com.docker.compose.network": "default",
"com.docker.compose.project": "testproject",
"com.docker.compose.version": "1.28.5"
}
}
]

SHELL实现批量断开与目标网络关联的容器:

#!bin/bash
for i in `docker network inspect -f '{{range .Containers}}{{.Name}} {{end}}' testproject_default`; \
do \
sudo docker network disconnect -f testproject_default $i; \
done;
if [ $? -ne 0 ]; then
echo "断开容器关联网络 testproject_default 失败"
exit 1
else
echo -e "断开容器关联网络 testproject_default 成功\n"
fi

注意:

实践时发现,这样以后,有时候还是会存在上述问题问题

解决方法:重启Docker

sudo service docker restart

Docker 根据网络名称批量断开与之相连的容器shell实现的更多相关文章

  1. 【Linux】【Services】【Docker】网络

    容器的网络模型: closed container: 仅有一个接口:loopback 不参与网络通信,仅适用于无须网络通信的应用场景,例如备份.程序调试等: --net none bridged co ...

  2. docker(4)docker的网络,自定义网桥

    Docker 的网络 运行 ifconfig 找到 docker0 : 虚拟网卡默认网卡名称为docker0 查看docker 的网桥: 我这里默认们没有进行安装 网桥管理设备:进行安装一下: yum ...

  3. docker从零开始网络(二)桥接网络

    使用桥接网络 在网络方面,桥接网络是链路层设备,它在网络段之间转发流量.桥接网络可以是硬件设备或在主机内核中运行的软件设备. 就Docker而言,桥接网络使用软件桥接器,该软件桥接器允许连接到同一桥接 ...

  4. Docker 基础 : 网络配置

    大量的互联网应用服务包含多个服务组件,这往往需要多个容器之间通过网络通信进行相互配合.Docker 目前提供了映射容器端口到宿主主机和容器互联机制来为容器提供网络服务.接下来我们将讲述 Docker ...

  5. Docker的网络类型和固定IP设置

    Docker的网络机制 Docker的网络有三种类型(driver): bridge, host 和 null. birdge: 就如同桥接的switch/hub, 使用bridge网络的contai ...

  6. Linux 将进程放入后台执行,解决网络,ssh断开导致进程结束(nohup, setsid, &, disown)

    Linux 将进程放入后台执行,解决网络,ssh断开导致进程结束(nohup,  setsid,  &, disown) 1.nohup 命令 我们知道,当用户注销(logout)或者网络断开 ...

  7. Docker源码分析(八):Docker Container网络(下)

    1.Docker Client配置容器网络模式 Docker目前支持4种网络模式,分别是bridge.host.container.none,Docker开发者可以根据自己的需求来确定最适合自己应用场 ...

  8. Docker源码分析(六):Docker Daemon网络

    1. 前言 Docker作为一个开源的轻量级虚拟化容器引擎技术,已然给云计算领域带来了新的发展模式.Docker借助容器技术彻底释放了轻量级虚拟化技术的威力,让容器的伸缩.应用的运行都变得前所未有的方 ...

  9. docker从零开始网络(七) 配置daemon和容器

    启用IPv6支持 在Docker容器或swarm服务中使用IPv6之前,需要在Docker守护程序中启用IPv6支持.之后,您可以选择将IPv4或IPv6(或两者)与任何容器,服务或网络一起使用. 注 ...

  10. docker从零开始网络(六)Macvlan

    使用Macvlan网络 某些应用程序,尤其是遗留应用程序或监视网络流量的应用程序,希望直接连接到物理网络.在这种情况下,您可以使用macvlan网络驱动程序为每个容器的虚拟网络接口分配MAC地址,使其 ...

随机推荐

  1. aspnetcore插件开发dll热加载 二

    这一篇文章应该是个总结. 投简历的时候是不是有人问我有没有abp的开发经历,汗颜! 在各位大神的尝试及自己的总结下,还是实现了业务和主机服务分离,通过dll动态的加载卸载,控制器动态的删除添加. 项目 ...

  2. 分享一个关于Avl树的迭代器算法

    1 研究过程 前段时间在研究avl树的迭代实现,在节点不使用parent指针的情况下,如何使用堆栈来实现双向地迭代.我参考了网络上的大部分迭代器实现,要么是使用了parent指针(就像c++的map容 ...

  3. sort awk 文本处理命令

    sort: 1.将文件的每一行作为一个单位,相互比较 2.默认升序 3.以字符来进行对比,从首字符开始往后,依次按ASCII码值排序 sort 显示文件内容 (类似cat) 选项: -u 去掉重复行 ...

  4. 利用nodejs的require.context来实现不用写impor导入组件

    先给你们看下目录结构 stuendt和teacharts还有util是同级 主要是componentRegister.js文件 function changStr(str) { return str. ...

  5. 改变函数中的this指向

      // 改变函数的this指向         // 先记住一句话 : 箭头函数不能改变this指向         // 语法1: call() 方法         //        在调用函 ...

  6. Ubuntu 上使能 SELinux

    首发公号:Rand_cs 此文档说明如何在 ubuntu 上启用 SELinux,测试环境为虚拟机,开始前一定一定一定先来个快照,不要问我为什么有三个一定. 卸载 apparmor(可选) ubunt ...

  7. 使用final shell 连接使用 ubuntu server linux

    书接上回,VM 安装ubuntu server:https://www.cnblogs.com/runliuv/p/16880599.html 1.从 https://www.hostbuf.com/ ...

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

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

  9. 将强化学习重新引入 RLHF

    我们很高兴在 TRL 中介绍 RLOO (REINFORCE Leave One-Out) 训练器.作为一种替代 PPO 的方法,RLOO 是一种新的在线 RLHF 训练算法,旨在使其更易于访问和实施 ...

  10. Flink状态(一)

    key状态和算子状态 key状态 key状态总是与key有关,只能被用于keyedStream类型的函数与算子.你可以认为key状态是一种被分区的算子状态,每一个key有一个状态分区.每一个key状态 ...