Docker容器互相连接三种实现方法详解

 更新时间:2020年05月27日 15:47:32   作者:流年似水zlw  
这篇文章主要介绍了Docker容器互连三种实现方法详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

docker容器间的互连通信有三种方法:

  • docker内部网络:不够灵活强大,不推荐
  • docker networking:1.9或更新版本,推荐使用
  • docker链接:1.9之前版本适用。

1.docker内部网络

涉及docker自己的网络栈。

安装docker后,系统会创建一个新的网络接口,名字是docker0,用于连接容器和宿主机,IP范围是172.16-172.30,

每个docker容器都会在这个接口上分配一个IP地址。

docker每创建一个容器就会创建一组互联的网络接口,一端是容器里的eth0接口,另一端则在宿主机以veth开头命名,

通过把每个veth接口绑定到docker0网桥,docker创建了一个虚拟子网,这个子网由宿主机和所有的docker容器共享,

实现容器和宿主机的通信连接,注意只有容器运行时veth接口才存在。

用内部网络实现容连互联的弊端:

  • 要在容器的应用程序里对另一个容器的IP地址做硬编码;
  • 容器重启后,IP地址可能会改变;
  • 不够方便和灵活。

2.docker networking

容器之间的连接用网络创建。

允许用户创建自己的网络,容器通过这个网络互相通信;

可以跨越不同的宿主机来通信,网络配置也更灵活;

可以在无需更新连接的情况下,停止、启动或者重启容器;

不必事先创建容器再去连接它,也不必关心容器的运行顺序,可以在网络内部获得容器名解析和发现;

和docker compose以及swarm进行了集成;

在docker网络内部启动的容器,会感知到所有在这个网络下运行的容器,

并通过/etc/hosts文件将这些容器的地址保存到本地DNS中,
网络内的任何主机都可以使用hostname或hostname.netname的形式来被解析访问,

如果任何一个容器重启了,其IP地址会自动在/etc/hosts文件中更新,

测试中发现/etc/hosts文件中好像没有新增其他容器的地址,但也能互相ping通;

一个容器可以同时加入多个网络,所以可以创建非常复杂的网络模型;

  • docker network create 创建一个网络
  • docker network inspect 查看网络的详细信息
  • docker network ls 列出当前系统中的所有网络
  • docker network connect 将已有容器连接到一个网络
  • docker network disconnect 从网络中断开一个容器
  • docker network rm 删除一个或多个网络
  • docker network prune 删除所有未使用的网络

3.docker链接

在链接过程中要引用到容器的名字,且只能工作于同一台宿主机中。

在docker run启动容器时用参数 --link 创建两个容器间的 客户-服务 链接,

需要两个参数,一个是链接容器的名字,一个是链接的别名,即 --link redis:db,

被链接的容器是服务,链接让服务容器能够和客户容器通信,

客户容器可直接访问服务容器的任意公开端口,所以服务容器的端口不需要对本地宿主机公开,相对更加安全;

可以把多个客户容器链接到同一个服务容器,也可通过指定多次--link来链接到多个服务容器,

docker在容器的/etc/hosts文件和包含链接信息的环境变量里写入链接信息;

无论采用哪种方式,都可以创建一个Web应用程序栈,包含以下组件:

  • 一个Web服务器容器
  • 一个Redis数据库容器
  • 两个容器间的一个安全链接

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • 使用OpenSSL生成Kubernetes证书的介绍

    使用OpenSSL生成Kubernetes证书的介绍

    今天小编就为大家分享一篇关于使用OpenSSL生成Kubernetes证书的介绍,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-01-01
  • docker中的jenkins配置sonarQube的过程

    docker中的jenkins配置sonarQube的过程

    SonarQube是一个开源的代码分析平台,用来持续分析和评测项目源代码的质量,通过SonarQube可以检测出项目中重复代码,潜在bug, 代码规范,安全性漏洞等问题,并通过SonarQube web UI展示出来,这篇文章主要介绍了docker中的jenkins配置sonarQube,需要的朋友可以参考下
    2023-08-08
  • 一文教会你在Docker容器中实现Mysql主从复制

    一文教会你在Docker容器中实现Mysql主从复制

    MySQL的主从复制之前也没做过,刚百度了下发现并不算难,所以下面这篇文章主要给大家介绍了关于在Docker容器中实现Mysql主从复制的相关资料,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2022-11-11
  • Docker 拉取 oracle 11g镜像配置的详细教程

    Docker 拉取 oracle 11g镜像配置的详细教程

    这篇文章主要介绍了Docker 拉取 oracle 11g镜像配置的详细教程,包括一些拉去镜像命令、创建容器、启动容器的相关知识,需要的朋友可以参考下
    2021-09-09
  • 教你使用Jenkins集成Harbor自动发布镜像

    教你使用Jenkins集成Harbor自动发布镜像

    这篇文章主要介绍了Jenkins 集成 Harbor 自动发布镜像,主要包括Jenkins 脚本式发布镜像及Jenkins 插件式发布镜像的详细过程,本文结合图文实例给大家介绍的非常详细,需要的朋友可以参考下
    2022-04-04
  • 在docker上安装运行mysql实例

    在docker上安装运行mysql实例

    Docker 使用 Google 公司推出的 Go 语言 进行开发实现,基于 Linux 内核的 cgroup,namespace,以及 AUFS 类的 Union FS 等技术,对进程进行封装隔离,属于操作系统层面的虚拟化技术。
    2017-01-01
  • docker安装后导致的网络问题及解决

    docker安装后导致的网络问题及解决

    这篇文章主要介绍了docker安装后导致的网络问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-11-11
  • Docker基础命令详解

    Docker基础命令详解

    Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上。本文给大家分享docker基础命令,感兴趣的朋友一起看看吧
    2016-10-10
  • docker容器详细讲解如何精简镜像减小体积

    docker容器详细讲解如何精简镜像减小体积

    这篇文章主要介绍了docker容器如何精简镜像减小体积,一般我们打造镜像会有几百MB,学完本文后我们将学会缩小镜像体积,从而达到做出来的镜像只有几十MB,一起来看看吧
    2021-08-08
  • docker搭建etcd集群方式 bitnami/etcd

    docker搭建etcd集群方式 bitnami/etcd

    这篇文章主要介绍了docker搭建etcd集群方式 bitnami/etcd,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-06-06

最新评论