Docker端口映射

news/2024/7/4 7:44:17 标签: docker, 容器, 运维, 云原生

目录

    • 前言
    • 端口映射
      • 随机映射:-P
      • 指定端口映射:-p

前言

在启动容器的时候,如果我们不指定对应参数,在容器外部是无法通过网络来访问容器内的网络应用和服务的。

那么我们如何从外部访问访问docker容器呢?这就要使用端口映射了,在Docker中,可以通过端口映射将容器内的端口映射到主机上,以实现容器与外部网络的通信。

端口映射

随机映射:-P

当我们使用-P(大写的)参数启动容器,就可以让Docker随机映射一个端口到容器内部开放的端口

docker run -P  image_name

要查看Docker映射随机端口的范围,可以使用以下命令:

sudo cat /proc/sys/net/ipv4/ip_local_port_range

输出结果将显示系统中允许分配的本地端口范围。例如,您可能会看到以下输出:

32768   60999

这表示Docker将分配主机上大于等于32768且小于等于60999的随机端口。

随机分配端口之后,我们可以使用docker ps 或者docker port来查看容器的端口映射,docker port会返回容器的端口映射关系,docker ps会返回运行中的容器信息

#docker port portainer
8000/tcp -> 0.0.0.0:8000
8000/tcp -> [::]:8000

8000/tcp -> 0.0.0.0:8000:表示容器内部的8000端口被映射到主机上的8000端口,可以通过主机的IP地址和端口8000来访问容器内的服务。

8000/tcp -> [::]:8000:表示容器内部的8000端口也被映射到主机上的8000端口,同时支持IPv6地址。

8000/tcp表示的是容器内的8000端口,0.0.0.0:8000表示的是主机的8000端口

指定端口映射:-p

-p(小写的)参数则可以指定要映射的端口,在一个指定端口上只可以绑定一个容器。支持的格式有IP:HostPort:ContainerPort | IP::ContainerPort |HostPort:ContainerPort。

映射到指定端口

HostPort:ContainerPort:使用HostPort:ContainerPort格式,可以指定本地端口映射到容器的哪个端口

 docker run -d -p 8000:80 --name nginx nginx

如上所示,就指定了宿主机的8000映射到容器内部的80端口

我们还可以多次使用-p标记可以绑定多个端口,如下所示

 docker run -d -p 8000:80 -p 5000:50  --name nginx nginx

映射到指定地址的指定端口

使用IP:HostPort:ContainerPort格式,可以指定映射的地址,比如localhost地址127.0.0.1:

docker run -d -p 127.0.0.1:8000:80 nginx

映射到指定地址,宿主机端口随机分配

使用 IP::ContainerPort格式,可以指定我们映射的地址,并且随机分配端口

docker run -d -p 127.0.0.1::80 nginx

注意:参数里是两个:


http://www.niftyadmin.cn/n/5280443.html

相关文章

sql server 增删改查(基本用法)

目录 1. 增 2. 删 3. 改 4. 查 1. 增 插入数据(INSERT): insert用于在数据库中插入数据 语法格式: INSERT INTO 表名 (列名, 列, ...) VALUES (值, 值, ...); 实列 insert into Student (name,age)val…

Sublime Text 3配置 C# 开发环境

Sublime Text 3配置 C# 开发环境 一、引言二、主要内容1. 初识 Sublime Text 32. 初识 C#3. 接入 .NET Framework3.1 下载 .NET Framework3.2 环境变量配置 4. 配置 C# 开发环境5. 编写 C# 代码6. 运行 C# 代码 三、总结 一、引言 C# 是一种面向对象的编程语言,由微…

四种常见的代码覆盖率测试

您听说过“代码覆盖率”吗?在这篇文章中,我们将探讨什么是测试中的代码覆盖率,以及四种衡量它的常用方法。 什么是代码覆盖率 代码覆盖率是衡量测试代码测试了源代码百分比多少的指标。它可以帮助您识别可能缺乏适当测试的代码区域。 通常…

Linux服务器 部署飞书信息发送服务

项目介绍: 飞书信息发送服务是指将飞书信息发送服务部署到一个Linux服务器上。飞书是一款企业级的即时通讯和协作工具,支持发送消息给飞书的功能。通过部署飞书信息发送服务,可以方便内网发送信息给外网飞书。 项目代码结构展示: …

版本控制器git与svn

1、svn SVN(是subversion的简称)是一款基于C/S架构的,非常优秀的版本控制器(可以简单的理解为管理代码的工具,在多人协同开发的时候,尤其重要),与传统的CVS(90年代左右&a…

Spring AOP入门指南:轻松掌握面向切面编程的基础知识

面向切面编程 1,AOP简介1.1 什么是AOP?1.2 AOP作用1.3 AOP核心概念 2,AOP入门案例2.1 需求分析2.2 思路分析2.3 环境准备2.4 AOP实现步骤步骤1:添加依赖步骤2:定义接口与实现类步骤3:定义通知类和通知步骤4:定义切入点步骤5:制作切面步骤6:将通知类配给…

Oracle数据库 19c OCP 082考题解析第10题

考试科目:1Z0-082 考试题量:90 通过分数:60% 考试时间:150min本文为云贝教育郭一军guoyJoe原创,请尊重知识产权,转发请注明出处,不接受任何抄袭、演绎和未经注明出处的转载。【云贝教育】Oracle…

KubePi JWT 默认密钥权限绕过漏洞复现(CVE-2023-22463)

0x01 产品简介 KubePi 是一款简单易用的开源 Kubernetes 可视化管理面板。 0x02 漏洞概述 KubePi 存在权限绕过漏洞,攻击者可通过默认 JWT 密钥获取管理员权限控制整个平台,使用管理员权限操作核心的功能。 0x03 影响范围 KubePi <= 1.6.2 0x04 复现环境 FOFA: ti…