允许使用 docker-compose 在两个 docker 桥接网络之间进行通信

2024-03-24

我正在使用 docker compose 创建相当复杂的 docker 容器基础设施。这些容器在 4 个不同的网络中运行(类似于我模仿的生产环境)。 Docker Compose 为我创建了这四个网络,并且一切正常,因为容器不会尝试与不同网络内的其他容器进行通信。当他们这样做时,连接就会断开。 我能够找出它被删除的原因,这是因为 Docker 将 iptables 规则添加到 DOCKER-ISOLATION 链中。 例子:

-A DOCKER-ISOLATION -i br-be010eaddd0e -o br-f788f16ed0dd -j DROP
-A DOCKER-ISOLATION -i br-f788f16ed0dd -o br-be010eaddd0e -j DROP

我写了一个小脚本,删除了我想要删除的规则(并允许所选网桥之间的通信),一切都像魅力一样工作,但不知何故,它们在某些时候由 Docker 重新创建,即使没有重新创建这些网络,所以它需要我再次运行该脚本,这非常烦人。 有什么方法可以明确告诉 Docker 允许两个网桥之间进行通信吗?或者也许有一些技巧可以在使用 Docker-Compose 启动容器后运行特定的 shell 脚本?


如果有人感兴趣,我已经设法用 iptables 来处理这个问题。解决方案是明确允许桥接子网之间的通信(假设它们具有固定的 IP 地址)。执行此操作的方法是发出以下命令(假设网桥子网为 172.24.131.0/24 和 172.24.132.0/24):

iptables -I FORWARD -s 172.24.131.0/24 -d 172.24.132.0/24 -j ACCEPT
iptables -I FORWARD -d 172.24.131.0/24 -s 172.24.132.0/24 -j ACCEPT

这样,我们就在 DOCKER-ISOLATION 之前在 FORWARD 链中添加新规则,它会强制 iptables 忽略这些子网之间的任何通信的整个 DOCKER-ISOLATION 链。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

允许使用 docker-compose 在两个 docker 桥接网络之间进行通信 的相关文章

随机推荐

  • 组件、行为和 MonoBehaviour 之间有什么区别?为什么这些是分开的?

    MonoBehaviour延伸Behaviour and Behaviour延伸Component 我想知道为什么这些类被分开以及这些类的语义含义 区分这些类有什么目的吗 是否有任何课程延伸Behaviour or Component直接地
  • Youtube Api playVideo 方法在某些移动设备上不起作用

    我正在尝试创建一个移动网站 点击图像后可以播放 YouTube 视频 我已经在几款 Android 手机 版本上进行了测试 有些手机的行为与预期不符 我的意思是它停止在缓冲并且永远不会播放视频 我注意到的另一件事是 播放器在用户触发视频播放
  • Eclipse GridData 的垂直滚动条

    我在 Eclipse 应用程序中有以下 Java 代码 import org eclipse swt layout GridData import org eclipse swt widgets List import org eclips
  • 如何从我的 Subversion 托管帐户创建转储文件?

    我的 SVN 存储库托管在某处 我想搬到别人那里去 如何创建存储库的转储以便将其导入到我的新主机中 这就是我一直看到的 svnadmin dump path to repos gt repos dump 我的存储库是托管的 因此它不是本地的
  • 在单独的函数中修改指向字符串文字的指针

    我希望这是一个微不足道的问题 有人可以用比我已经遇到的更简单的术语向我解释 在工作过程中 C 之旅 第二版 我一直在尝试几个例子 我目前正在尝试在单独的函数中修改指向字符串文字的指针 我认为这很容易 using namespace std
  • 小块饼图上的标签(ggplot)

    我想用ggplot制作饼图 My data lab lt c a b c d e f g h percentage lt c 50 20 10 10 2 2 2 2 df prison lt data frame lab percentag
  • 如何设置内联集合?

    例如 DataTable table new DataTable Columns new DataColumnCollection new DataColumn col1 new DataColumn col2 你说的是集合初始化器 htt
  • 完全用汇编语言编写操作系统有什么好处? [关闭]

    Closed 这个问题是基于意见的 help closed questions 目前不接受答案 MenuetOS http en wikipedia org wiki MenuetOS是完全用汇编编写的操作系统的示例 用汇编语言编写它比用
  • 在 Visual Basic 6 中对 Excel 工作表进行编码

    我想将excelsheet1的列A的值获取到Visual Basic的某个变量中 然后在更改该值后发送回下一个sheet2 这是一个完整且有效的项目示例 它将值从 Sheet1 单元格 A1 复制到 Sheet2 单元格 A1 declar
  • C# 中的空可扩展树节点

    我想在 C 中创建一个可扩展的空树节点 即一个空的树节点 旁边有 符号 原因是因为最初它是空的 但是一旦单击一个节点 我想用许多子节点填充它 我面临的唯一问题是空树节点不可扩展 所以我不知道该怎么办 有没有办法解决这个问题 或者有什么解决方
  • AF-XDP:实现共享 Umem 套接字

    我想实现 XDP SHARED UMEM https www kernel org doc html latest networking af xdp html xdp shared umem bind flag https www ker
  • c:out 和使用 $ 打印输出之间的区别

    在 JSTL 中有两种打印输出的方法 h1 h1
  • hh_client 报告包错误

    我正在按照中的说明进行操作入门 https docs hhvm com hack getting started starting a real project在 Hacklang 官方网站上 正如它所说 我运行 touch hhconfi
  • 在包中包含一个“哈希表”

    我正在整理一个我已经工作了近一年的包 我有一个音节查找函数所需的哈希表 哈希表实际上只是一个环境 我想我不是计算机高手 它是一个查找表 您可以在下面看到我创建它的函数 我有一个数据集DICTIONARY 约 20 000 个字 将在加载包时
  • 在JAVA中从字符串(从url类型更改)中删除尾部斜杠

    我想从 Java 中的字符串中删除尾部斜杠 我想检查字符串是否以 url 结尾 如果是 我想删除它 这是我所拥有的 String s http almaden ibm com s s replaceAll 和这个 String s http
  • 使用 jQuery 创建新的 html5 视频对象

    如何使用 jQuery 创建视频元素 并将其属性 例如 control 添加到 true
  • Python 和 MySQL:有 MySQLdb 的替代品吗?

    是否有一个纯粹用 Python 编写的模块允许脚本与 MySQL 数据库通信 我已经尝试过 MySQLdb 但没有成功 它需要太多 GCC zlib 和 openssl 我无法使用这些工具 即使我这样做了 我也不想浪费时间让他们一起工作 我
  • 使用Camel的spring-rabbitmq组件时如何自动声明交换?

    我正在尝试从 Camel 3 x 迁移到 Camel 4 x 版本 因此我需要从rabbitmq替换组件spring rabbitmq With rabbitmq我正在使用的组件declare https camel apache org
  • 如何自动滚动到网格视图的末尾?

    当我将项目添加到网格视图的末尾时 我希望用户看到已添加的内容 这是我的意思的一个例子 用户通过按 图标添加项目 问题是在第 14 项之后没有任何反馈表明已添加任何项目 当最后一项添加到列表中时 如何自动滚动到最后一项 奖励点 当第 n 个项
  • 允许使用 docker-compose 在两个 docker 桥接网络之间进行通信

    我正在使用 docker compose 创建相当复杂的 docker 容器基础设施 这些容器在 4 个不同的网络中运行 类似于我模仿的生产环境 Docker Compose 为我创建了这四个网络 并且一切正常 因为容器不会尝试与不同网络内