「解析」docker容器起服务,外部访问失败

将服务打包docker镜像时发现postman请求失败,以下是服务测试代码

python 复制代码
# @Author :  绿色羽毛
# @Email  :  lvseyumao@foxmail.com
# @Blog   :  https://blog.csdn.net/ViatorSun
# @Note   :


import os
import cv2
import uvicorn
from fastapi import FastAPI, Request, HTTPException
from fastapi.responses import JSONResponse, StreamingResponse


app = FastAPI()
@app.post("/video")
async def server(request: Request):
    try:
        data = await request.json()
        rtsp_url = data["rtsp_url"]
        print(f"==== {rtsp_url}")

    except json.JSONDecodeError:
        raise HTTPException(status_code=400, detail="Invalid JSON format")


if __name__ == '__main__':
    uvicorn.run(app, host="0.0.0.0", port=8080)

端口为8080,在起docker镜像时,需要将容器端口跟宿主机端口映射成功,可以通过 docker ps 命令查看,可以看到 PORTS已经将8080端口映射成功

但是使用 postman 进行请求测试的时候,会发现使用 http://localhost:8080/video 进行请求时会导致失败

原因分析,及解决方案

使用 docker inspect 查看容器详细信息

shell 复制代码
# docker inspect <container_id_or_name>		# 命令
docker inspect 54c2afaaf8e4

主要的问题发生在,在 Docker 容器中运行应用时,127.0.0.1 是容器内部的本地地址。使用 127.0.0.1:8080,则只会使服务对 容器内 的请求可用,而容器外的请求(例如从主机或 Postman 进行的请求)会被拒绝连接。

解决方法:

  1. 首先修改 uvicorn.run 中的 host 参数,将其改为 0.0.0.0,这样服务就会绑定到所有网络接口(即允许来自外部的连接)
  2. 然后通过 docker inspect <container_id_or_name> 查看容器的详细配置和端口映射
    • "Gateway": "172.17.0.1":这个字段表示容器所在网络的默认网关地址。在 Docker 默认的网络驱动(bridge模式)下,容器和宿主机的通信通常通过这个网关进行。该网关地址通常是 Docker 默认桥接网络(bridge)的地址。
    • "GlobalIPv6Address": "" :这个字段表示容器的全局 IPv6 地址。由于该字段为空,表示容器没有配置全局 IPv6 地址。在默认情况下,Docker 不会为容器启用 IPv6,除非显式配置。
    • "GlobalIPv6PrefixLen": 0:这个字段表示容器的全局 IPv6 地址的前缀长度,通常用于定义子网的大小。因为没有配置 IPv6 地址,这个值是 0。
    • "IPAddress": "172.17.0.2":这个字段表示容器在当前网络(默认情况下是 Docker 的桥接网络 bridge)中的 IP 地址。在这种情况下,容器的 IP 地址是 172.17.0.2,这是容器在桥接网络中的内网地址。

在此,主要查看 IPAddress 属性,IPAddress 表示容器在当前网络中的 ip地址,即容器在桥接网络中的内网地址

最后再使用 postman 进行 http://172.17.0.2:8080/video 测试发现可以正常请求

相关推荐
小鹏linux25 分钟前
【linux】进程与服务管理命令 - chkconfig
linux·运维·服务器
DeeplyMind1 小时前
linux VMA创建场景详解
linux·mmap·vma
扛枪的书生1 小时前
Ansible 学习总结
linux
赵民勇2 小时前
cut命令详解
linux·shell
阿常呓语2 小时前
colima 的简单使用
docker·colima
闻道且行之2 小时前
Linux|CUDA与cuDNN下载安装全指南:默认/指定路径双方案+多CUDA环境一键切换
linux·运维·服务器
Ahtacca2 小时前
Linux环境下前后端分离项目(Spring Boot + Vue)手动部署全流程指南
linux·运维·服务器·vue.js·spring boot·笔记
_w_z_j_2 小时前
Linux----Socket编程基础
linux·运维·服务器
默|笙2 小时前
【Linux】进程控制(3)进程程序替换
android·linux·运维
老前端的功夫3 小时前
TypeScript 全局类型声明:declare关键字的深度解析与实战
linux·前端·javascript·ubuntu·typescript·前端框架