设为首页 收藏本站
查看: 1228|回复: 0

[经验分享] Docker容器之内网独立IP访问

[复制链接]

尚未签到

发表于 2019-2-21 08:27:10 | 显示全部楼层 |阅读模式
Docker容器之内网独立IP访问

实验介绍
  今天在学习Docker容器的时候,在虚拟机中创建并开启了一个nginx的container,然后通过端口映射的方法,即将container的80端口映射到虚拟机的80端口,然后在宿主机上通过访问虚拟机的IP从而访问到Docker容器的Nginx服务。
  然后开始思考,能否通过分配给container一个独立的IP,然后在宿主机上访问这个独立IP从而访问Nginx服务。通过各种探索,百度,最终实现,下面开始实验,这里用的是虚拟机的NAT模式。

实验图解


实验实施


  • 安装docker服务
    [root@promote ~]# yum install docker -y
  • 关闭防火墙和SElinux
    [root@promote ~]# systemctl stop firewalld.service
    [root@promote ~]# setenforce 0
  • 开启docker服务
    [root@promote ~]# systemctl start docker.service
    [root@promote ~]# systemctl enable docker.service
    Created symlink from /etc/systemd/system/multi-user.target.wants/docker.service to /usr/lib/systemd/system/docker.service.
    #将docker服务设置为开机启动
  • 启动docker服务后,我们可以通过命令从服务端先搜索nginx镜像。

  • 下载星级最高的nginx镜像,这里顺便说一下使用aliyun的docker源配置。

  • 下载nginx服务镜像。
    [root@promote etc]# docker pull docker.io/nginx
    Using default tag: latest
    Trying to pull repository docker.io/library/nginx ...
    latest: Pulling from docker.io/library/nginx
    be8881be8156: Pull complete
    32d9726baeef: Pull complete
    87e5e6f71297: Pull complete
    Digest: sha256:d85914d547a6c92faa39ce7058bd7529baacab7e0cd4255442b04577c4d1f424
    Status: Downloaded newer image for docker.io/nginx:latest
  • 在虚拟机中创建一个自定义网络
    [root@promote etc]# docker network create --subnet=172.20.0.0/24 docker-br0
    f900579310b9e692ab5a2593d9845be24166120a9de1c16e3143fa5a9c875f96
    #创建一个172.20.0.0网段,网桥的名字命名为docker-br0,这两个根据自己需要来


  • 在自定义的网段中选取一个IP作为container的IP来启动。
    [root@promote etc]# docker images
    REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE
    docker.io/nginx     latest              c82521676580        2 weeks ago         109 MB
    #查看我们下载下来的镜像,下面会用到IMAGE ID
    [root@promote etc]# docker run -itd --net docker-br0 --ip 172.20.0.10 --name nginx c82521676580 /bin/bash
    a2da3616efd0c53745fd7b33823733598be749c83cd4a84f72025664837b3a77
    #i表示保持容器打开,t表示给docker分配一个伪终端,d表示以daemon守护进程的方式开启
    #--net指定网桥名称,--ip指定启动ip ,--name指定服务名称
    [root@promote etc]# docker ps -a
    CONTAINER ID        IMAGE               COMMAND             CREATED             STATUS              PORTS               NAMES
    a2da3616efd0        c82521676580        "/bin/bash"         4 minutes ago       Up 4 minutes        80/tcp              nginx
    #可以看到服务已经启动
  • 进入到容器中安装一些工具
    [root@promote etc]# docker exec -it nginx /bin/bash
    #nginx就是上面指定的name
      这个时候我们使用ifconfig

    root@a2da3616efd0:/# ifconfig
    bash: ifconfig: command not found
    #可以看到并没有这个命令,所以我们需要安装net-tools工具
  一开始我以为使用yum方式安装,发现没用, 后来查看系统命令发现,容器里面使用的是Debian Linux的apt-get命令,首先要更新源。

root@a2da3616efd0:/# apt-get update
#update 是更新 /etc/apt/sources.list 和 /etc/apt/sources.list.d列出的源地址,获取最新软件包信息。
Get:1 http://security.debian.org/debian-security stretch/updates InRelease [94.3 kB]
Get:3 http://security.debian.org/debian-security stretch/updates/main amd64 Packages [386 kB]
Ign:2 http://cdn-fastly.deb.debian.org/debian stretch InRelease                          
Get:4 http://cdn-fastly.deb.debian.org/debian stretch-updates InRelease [91.0 kB]
Get:5 http://cdn-fastly.deb.debian.org/debian stretch Release [118 kB]
Get:6 http://cdn-fastly.deb.debian.org/debian stretch-updates/main amd64 Packages [5148 B]
Get:7 http://cdn-fastly.deb.debian.org/debian stretch Release.gpg [2434 B]
Get:8 http://cdn-fastly.deb.debian.org/debian stretch/main amd64 Packages [7099 kB]
Fetched 7796 kB in 1min 50s (70.8 kB/s)                                                  
Reading package lists... Done
root@a2da3616efd0:/proc# apt-get upgrade
#升级已经安装的软件包即update中的
Reading package lists... Done
Building dependency tree      
Reading state information... Done
Calculating upgrade... Done
0 upgraded, 0 newly installed, 0 to remove and 0 not upgraded.
root@a2da3616efd0:/proc# apt-get install net-tools
#安装net-tools软件包
Reading package lists... Done
Building dependency tree      
Reading state information... Done
The following NEW packages will be installed:
net-tools
0 upgraded, 1 newly installed, 0 to remove and 0 not upgraded.
Setting up net-tools (1.60+git20161116.90da8a0-1) ...

  • 查看容器的ip地址

  • 开启Nginx服务
    root@a2da3616efd0:~# nginx
    root@a2da3616efd0:~# netstat -ntap
    Active Internet connections (servers and established)
    Proto Recv-Q Send-Q Local Address           Foreign Address         State       PID/Program name   
    tcp        0      0 0.0.0.0:80              0.0.0.0:*               LISTEN      232/nginx: master p
    tcp        0      0 127.0.0.11:42541        0.0.0.0:*               LISTEN      -  
    #nginx服务已经开启,系统80端口也已经打开。
      我们在虚拟机环境下,用172.20.0.10测试是否能访问nginx默认首页。


  •   到物理机win10中访问172.20.0.10,测试是否能访问

    结果就是并不能访问nginx,我们尝试使用win10来ping172.20.0.10。


  • 尝试开启路由转发


  • 分别查看container和win10的路由表




  •   这时候我们再来在win10上访问172.20.0.10.发现可以访问了。



  •   最后我们将虚拟机中的路由转发关闭试试



  • 最后总结
    1、创建自定义网段
    2、选一个自定义网段内的IP,开启容器
    3、开启虚拟机的路由转发
    4、在物理机路由中添加自定义网段的路由条目,指定接口为虚拟机的IP地址




运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-675097-1-1.html 上篇帖子: Docker架构(一)安装及镜像操作 下篇帖子: Docker部署nginx并修改配置文件
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表