docker desktop的容器间通信

docker desktop的网络设置

在 Docker 中,当勾选 "Enable host networking",并使用--net=host参数启动容器时:

  • 和宿主机通信 :容器可以直接使用宿主机的网络栈,这意味着容器和宿主机共享相同的网络命名空间。容器内监听的端口,会直接暴露在宿主机上,无需进行端口映射。比如容器内的服务监听在8080端口,在宿主机上可以直接通过localhost:8080访问该服务。
  • 不同容器间通信 :如果多个容器都使用了主机网络模式(--net=host),由于它们都共享宿主机的网络命名空间,那么可以通过localhost:端口 直接进行通信。 但如果只有部分容器使用主机网络模式,其他容器使用默认的桥接网络等模式,那么使用主机网络模式的容器和其他容器通信,就不能单纯通过localhost:端口了。因为不同网络模式下容器的网络环境不同,需要根据具体网络配置,比如桥接网络中容器有自己独立的 IP 地址,需要通过桥接网络内的 IP 和端口来通信 。

如果不勾选 "Enable host networking",默认情况下容器运行在桥接网络模式,容器有自己独立的网络命名空间,容器之间以及容器与宿主机之间通过 NAT(数据通信是需要经过网卡的)和端口映射来通信,此时不能直接通过localhost:端口(不经过网卡)在不同容器间通信。

需要通过ipconfig查看本机ip(或者wsl的ip),通过这个ip进行不同容器间的通信。

或者通过docker inspect查看容器ip addr,使用这个ip通信。

docker创建自定义网络

创建自定义网络

docker network create aichat-network

将所有的容器添加到网络中

docker network connect aichat-network neo4j

docker network connect aichat-network aichat

docker network connect aichat-network postgres

docker network connect aichat-network redis

docker network connect aichat-network ollama

查看容器是否添加到网络中

docker inspect aichat-network

如此设置,docker之间就可以通过 url: jdbc:postgresql://postgres:5432/ai容器名通信

相关推荐
helloworddm3 小时前
Orleans 与 Kubernetes 结合的价值分析
云原生·容器·kubernetes
KubeSphere 云原生4 小时前
云原生周刊:Helm 十年,成就 Kubernetes 的生态中枢
云原生·容器·kubernetes
key_Go4 小时前
12.docker swarm
运维·docker·容器·docker swarm
007php0075 小时前
百度面试题解析:synchronized、volatile、JMM内存模型、JVM运行时区域及堆和方法区(三)
java·开发语言·jvm·缓存·面试·golang·php
码农阿豪5 小时前
一个浏览器多人用?Docker+Neko+cpolar实现跨网共享
运维·docker·容器
荣光波比5 小时前
K8S(十)—— Kubernetes核心组件详解:Pod控制器与配置资源管理
java·容器·kubernetes
KevinLyu7 小时前
内存管理篇(一)· zend_alloc 的基本概念
php
奋斗的蛋黄7 小时前
K8s 核心三组件:kubelet、kubeadm、kubectl 知识点梳理
云原生·容器·kubernetes
星光一影8 小时前
大型酒店管理系统源码(多酒店版)
mysql·php