『中级篇』docker网络(23)

从本节开始,docker新的章节的学习,docker网络。net-work中在日常的开发和运维上运用,建立一个服务,访问一个数据库,都需要网络的了解。docker单机,多机。

####单机

  • bridge NetWork(桥接网络)
  • Host NetWork (主机网络)
  • None NetWork (无网络)

####多机

  • overlay network(覆盖网络)

本节还是通过源码+截图的方式来学习,已经把源码上传到我的github账号上了,

https://github.com/limingios/docker.git

####编辑多机Vagrantfile

  • 本节还是通过vagrant的方式来创建虚拟机,在github中No.2里面有个Vagrantfile
# -*- mode: ruby -*-
# vi: set ft=ruby :

Vagrant.require_version ">= 1.6.0"

boxes = [
    {
        :name => "docker-node1",
        :mem => "1024",
        :cpu => "1"
    },
    {
        :name => "docker-node2",
        :mem => "1024",
        :cpu => "1"
    }
]

Vagrant.configure(2) do |config|

  config.vm.box = "centos/7"

  boxes.each do |opts|
      config.vm.define opts[:name] do |config|
        config.vm.hostname = opts[:name]
        config.vm.provider "vmware_fusion" do |v|
          v.vmx["memsize"] = opts[:mem]
          v.vmx["numvcpus"] = opts[:cpu]
        end

        config.vm.provider "virtualbox" do |v|
          v.customize ["modifyvm", :id, "--memory", opts[:mem]]
          v.customize ["modifyvm", :id, "--cpus", opts[:cpu]]
        end

        config.vm.network :private_network, type: "dhcp"
      end
  end

  config.vm.synced_folder "./labs", "/home/vagrant/labs"
  config.vm.provision "shell", privileged: true, path: "./setup.sh"

end
  • vagrant 创建虚拟机
vagrant up
image.png
  • 查看ip地址node1和node2

打开2个窗口分别登录docker-node1 和docker-node2

vagrant ssh docker-node1
ifconfig
vagrant ssh docker-node2
ifconfig
  • 主机ping去ping node1 和node2 看能否ping通
#不通的机器可能ip不相同,这个问题,根据查看得来的
ping 172.28.128.3
ping 172.28.128.4
image.png

PS:本机基本上docker的多虚拟机网络已经完成了,比较简单,毕竟是演示环境,可能有老铁说,为啥设置成了自动获得IP,而不是静态IP,毕竟是学习的环境,我也尝试改成过静态IP但是ping不通,其实我的思路就是先让计算机帮我设置一个自动获取的IP,我可以在他的基础上设置自己的静态ip,这样保证可以用,对于静态IP如何设置我也写一份静态IP的配置吧,跟上边差距不太大。

还有老铁说 我不太习惯用vagrant 我喜欢用docker-machine,这个都无所谓了,其实重点是吧环境搭建起来。

#静态版本的。
# -*- mode: ruby -*-
# vi: set ft=ruby :

Vagrant.require_version ">= 1.6.0"

boxes = [
    {
        :name => "docker-node1",
        :mem => "1024",
        :eth1=>"172.28.128.3",
        :cpu => "1"
    },
    {
        :name => "docker-node2",
        :mem => "1024",
        :eth1=>"172.28.128.4",
        :cpu => "1"
    }
]

Vagrant.configure(2) do |config|

  config.vm.box = "centos/7"

  boxes.each do |opts|
      config.vm.define opts[:name] do |config|
        config.vm.hostname = opts[:name]
        config.vm.provider "vmware_fusion" do |v|
          v.vmx["memsize"] = opts[:mem]
          v.vmx["numvcpus"] = opts[:cpu]
        end

        config.vm.provider "virtualbox" do |v|
          v.customize ["modifyvm", :id, "--memory", opts[:mem]]
          v.customize ["modifyvm", :id, "--cpus", opts[:cpu]]
        end

        config.vm.network :private_network,ip: opts[:eth1]
      end
  end

  config.vm.synced_folder "./labs", "/home/vagrant/labs"
  config.vm.provision "shell", privileged: true, path: "./setup.sh"

end
image

原创声明,本文系作者授权云+社区发表,未经许可,不得转载。

如有侵权,请联系 yunjia_community@tencent.com 删除。

编辑于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏IMWeb前端团队

Node.js必须收藏,五大应用性能技巧

Nodejs/web前端 权威大牛交流群:550392000 ,更多免费视频资料+源码~ 大家赶紧收藏起来吧~ 一、实现一个反向代理服务器 相比大多数应用服务器...

22610
来自专栏JAVA高级架构

高并发面试必问:分布式消息系统Kafka简介

2413
来自专栏北京马哥教育

用开源自动化运维工具 SaltStack 在云平台中实现各主机统一配置管理

本文将主要介绍开源软件 SaltStack 自动化运维工具在大型云计算环境中,如何帮助管理员快速完成运维任务,降低运维工作量,提高效率。根据不同业务特性,进行...

4595
来自专栏JackeyGao的博客

ANSIBLE模块 - shell和command区别

Ansible 提供了大量的模块(All Modules)供执行 AD-Hoc 和撰写 playbook。 有些模块有很多通用性, 但设计为多个还是有部分区别的...

851
来自专栏Youngxj

emlog最新文章邮件推送插件1.1

2715
来自专栏谦谦君子修罗刀

淘宝镜像Mock模拟服务器后台数据

早已看见多了一个新玩意儿,便料定是模拟数据之物,忙来细看。厮见毕归坐,细看形容,与众各别:两行似教非教简介书,一组似跨非跨显示栏。态生网页之姿,承袭后台之力。 ...

4276
来自专栏java思维导图

分布式事务的实现方法及替代方案

图的上半是两阶段提交成功的演示, 下半是两阶段提交失败的演示. 关于两阶段提交网上有很多经典的讲解, 这里就不细说了

1394
来自专栏云计算

使用Ansible自动化管理云上或者本地的基础设施

Ansible任务是幂等的。通常在没有额外编码的情况下,单单调用脚本重复执行通常是不安全的。而Ansible在执行任务之前都会收集当前的系统和环境信息作为上下文...

2355
来自专栏北京马哥教育

误删重要文件怎么办?学会Linux 救援模式再也不担心

背景 在运用Linux时会出现一些误操作,导致系统无法正常使用,比如删除了某个重要依赖库,或者删除了rpm等等。在这里记录下具体的操作步骤,供以后参考。 意义 ...

3899
来自专栏.NET后端开发

RabbitMQ消息队列系列教程(一)认识RabbitMQ

摘要 RabbitMQ是最为流行的消息中间件,是处理高并发业务的利器。本系列教程,将跟大家一起学习RabbitMQ。 目录 RabbitMQ是什么? Rabbi...

3398

扫码关注云+社区