docker的端口重定向详解

docker的端口重定向,一般程序同服务进行连接的时候都是通过端口进行的,当一个服务运行在容器内部,你可以通过绑定在该容器上的IP地址和端口连接该服务。但是容器的这个IP地址是一个本地的IP地址,并且容器内部运行的服务的端口在外面是不可达的。docker容器关于IP地址的这个问题刚好提供一个简单的方法来访问容器内部的服务。

允许非本地的客户端来访问容器内部的服务,docker提供了绑定容器的服务端口到本地系统IP的方法,这样就可以简单的在多个容器间进行通讯,docker提供了连接机制。

1    自动映射EXPOSE端口到本地系统

可以使用-P参数自动的绑定所有EXPOSE容器的端口到本地系统,这个映射端口会自动的在49000-49900直接选择,你可以使用docker ps或者docker inspect或者docker port来查看端口具体映射到那个port上。

2    绑定一个容器端口到本地系统

你也可以使用-p参数绑定一个容器的端口到本地系统的IP地址上,在docker run命令中使用如下:
docker run -p [([<host_interface>:[host_port]])|(<host_port>):]<container_port>[/udp] <image> <cmd>
        如果你没有指定本地主机IP接口,则默认绑定到所有可用的IP接口上,假如你没有提供主机端口,则会自动选择一个进行绑定。默认是使用TCP端口,不过你也可以明确指定使用UDP端口。docker port命令可以列出容器的端口和本地主机的哪个IP和端口进行自动映射的。

3    连接到一个容器

在两个容器之间也是可以建立连接的,假如我们有两个容器,一个是server,一个是client,在server启动后,client启动连接到server。连接用到的一些环境变量参数在client上提供。我们注意到server的IP地址在每次启动后都不是固定的,但是在client中会使用到一些server的信息,由于client是在server之后启动的,所以client还是可以识别到一些server的信息的,下面我们看看基本步骤:

1    启动一个server
docker run --expose 80 --name server <image> <cmd>
        2    client连接到server
docker run --name client --link server:linked-server <image> <cmd>
                --link   server:linked-server,表示连接到server这个容器,并且把该server信息连接到linked-server这个变量上

3    在client上查看server的一些信息
env |grep -i linked-server
                         你就会看到关于server的一些信息

更多精彩内容请关注:http://bbs.superwu.cn

关注超人学院微信二维码:

时间: 2024-10-21 20:24:17

docker的端口重定向详解的相关文章

Docker基础 :网络配置详解

本篇文章将讲述 Docker 的网络功能,包括使用端口映射机制来将容器内应用服务提供给外部网络,以及通过容器互联系统让多个容器之间进行快捷的网络通信,有兴趣的可以了解下. 大量的互联网应用服务包含多个服务组件,这往往需要多个容器之间通过网络通信进行相互配合.Docker 目前提供了映射容器端口到宿主主机和容器互联机制来为容器提供网络服务.接下来我们将讲述 Docker 的网络功能,包括使用端口映射机制来将容器内应用服务提供给外部网络,以及通过容器互联系统让多个容器之间进行快捷的网络通信. 端口映

Docker:网络模式详解

Docker作为目前最火的轻量级容器技术,牛逼的功能,如Docker的镜像管理,不足的地方网络方面. Docker自身的4种网络工作方式,和一些自定义网络模式 安装Docker时,它会自动创建三个网络,bridge(创建容器默认连接到此网络). none .host.Container host:容器将不会虚拟出自己的网卡,配置自己的IP等,而是使用宿主机的IP和端口. Container:创建的容器不会创建自己的网卡,配置自己的IP,而是和一个指定的容器共享IP.端口范围. None:该模式关

完成端口(CompletionPort)详解

手把手叫你玩转网络编程系列之三    完成端口(Completion Port)详解                                                              ----- By PiggyXP(小猪) 前 言 本系列里完成端口的代码在两年前就已经写好了,但是由于许久没有写东西了,不知该如何提笔,所以这篇文档总是在酝酿之中--酝酿了两年之后,终于决定开始动笔了,但愿还不算晚-.. 这篇文档我非常详细并且图文并茂的介绍了关于网络编程模型中完成端口的方方

Linux I/O 重定向详解及应用实例

简解 > 输出 < 输入 >> 追加 & [> | < | >>]之前:输入输出; ls /dev &>filename #"&"在这里代表标准输出和标准错误,这里无论是正常输出还是错误信息都写到filename中了. [> | < | >>]之后:重定义文件标志符 echo 123 1>&tmp #相当于 echo 123 : echo 123 > tmp. &q

CISCO设备之端口聚合详解

最近发现MDT推出去的系统的有不同问题,其问题就不说了,主要是策略权限被域继承了.比如我们手动安装的很多东东都是未配置壮态,推的就默认为安全壮态了,今天细找了一下,原来把这个关了就可以了. CISCO设备之端口聚合详解

10_Shell语言———I/O重定向详解

一.什么是I/O I/O设备是计算机核心部件和外围设备进行交互的通道,因此I/O是一个统称.但这里所说的I/O与计算机的硬件设备没有太大关系,它是用来实现应用程序的I/O重定向.通常应用程序需要从外部用户获取数据,也需要将运行结果反馈给外部用户,因此程序本身要有输入输出功能,也就是和用户进行交互的功能,那么在Linux中,用户需要在命令行里为程序指定输入输出设备以便程序获取和反馈数据. Linux的基本哲学思想是:1)一切皆文件:2)尽可能避免捕获用户接口:3)由众多目的单一应用程序组成:一个程

新浪sae url rewrite(伪静态、重定向)详解

新浪sae url rewrite(伪静态.重定向)详解 http://www.veryhuo.com phpclubs 2011-11-14 投递稿件 sae全程Sina App Engine,真是一个好东西,他有很多优秀的特性,简单来说SAE就是一个简单高效的分布式Web服务开发.运行平台. 支持现在常用的 php+mysql环境,在开发中难免会碰到项目需要做url rewrite(伪静态),然而sae不支持 apache 下的.htaccess .不过不要难过,sae提供了自己的rewri

6.9 docker(一) Dockerfile 指令详解

Dockerfile 指令详解 COPY 复制文件 格式: COPY [--chown=<user>:<group>] <源路径>... <目标路径> COPY [--chown=<user>:<group>] ["<源路径1>",... "<目标路径>"] 一种类似于命令行,一种类似于函数调用 <源路径> 的文件/目录复制到新的一层的镜像内的 <目标路

保证Linux系统安全之firewalld防火墙配置地址伪装和端口转发详解

通过保证Linux系统安全之firewalld防火墙入门详解认识Linux系统firewalld防火墙,并可以编写一些相对简单一些的防火墙规则.Linux防火墙可以充当路由器(网关).路由器上的NAT技术,同样可以通过Linux防火墙来实现.地址伪装和端口转发说白了就是路由器中的NAT技术. 一.地址伪装和端口转发简介 firewalld防火墙支持两种类型的NAT: (1)地址伪装 地址伪装:基于源地址进行转换,通过地址伪装,NAT设备将经过设备的数据包转发到指定接收方,同时将通过的数据包的源地