AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / computer / 问题 / 1703171
Accepted
kankan256
kankan256
Asked: 2022-02-05 05:55:47 +0800 CST2022-02-05 05:55:47 +0800 CST 2022-02-05 05:55:47 +0800 CST

TCP 握手是由 Web 应用程序烧瓶或 Web 服务器(如 nginx)处理的吗?

  • 772

如果我在端口 5000 上以开发模式运行一个简单的烧瓶应用程序(因此 Web 服务器和 Web 应用程序是烧瓶库)。有没有办法查看客户端和服务器之间交换的 SYN、SYN-ack、ack 请求?例如,打印它们?我不想使用 Wireshark 之类的工具来查看流量,我想知道谁在处理这个过程。

from flask import Flask
app = Flask(__name__)


@app.route('/')
def index():
    return 'hello'

当我做curl localhost:5000/curl 首先发送 SYN?谁来回答?烧瓶?

我该怎么做才能在我自己的应用程序上看到所有这些过程?另外,我想看看 HTTP/1.1 的 keep-alive 机制是如何工作的?

tcp flask
  • 1 1 个回答
  • 426 Views

1 个回答

  • Voted
  1. Best Answer
    user1686
    2022-02-05T06:16:14+08:002022-02-05T06:16:14+08:00

    TCP 握手是由 Web 应用程序烧瓶或 Web 服务器(如 nginx)处理的吗?

    两者都不。对于 TCP,握手完全由操作系统处理。

    cURL 使用操作系统提供的“sockets API”启动连接——通常是 socket() 和 connect() 函数——而 Flask 的开发服务器使用 listen() 和 accept() 接收它。当 accept() 函数返回时,整个 TCP 握手已经完成,Flask 可以使用套接字获取数据了。

    这意味着您尝试查看的过程根本不是您的应用程序的一部分。Flask 只使用 Python 的socket.socket()对象,然后直接调用相应的 OS 函数——您需要使用 dtrace/bpftrace/systemtap 等 OS 跟踪工具来查看发生的内部内核调用。

    尽管请注意 QUIC(如在 HTTP/3 中)的工作方式略有不同——操作系统中没有直接的 QUIC 支持,因此执行 QUIC 握手的是cURL 和 Nginx,尽管它们仍然使用像 ngtcp2 或 MsQuic 之类的库来完成所有操作工作。(端点仍然使用“套接字 API”与操作系统对话,但对于 QUIC,它们创建了 UDP 套接字,这些套接字不实现自己的握手。)

    如何手动将 SYN 数据包发送到本地网络中的计算机?

    与数据包捕获工具类似,还有数据包生成工具可让您制作自定义数据包(甚至可能创建自己的 TCP 堆栈)。其中之一是scapy,它是用 Python 编写的,可让您使用 Python REPL 手动构建数据包。另一个类似的选项是pypacker模块,同样在 Python 中。

    此类工具通常使用“原始套接字”,这与 UDP 非常相似,只是应用程序可以包含自己的 IP 标头。您通常需要 root 权限才能使用它。

    另外,我想看看 HTTP/1.1 的 keep-alive 机制是如何工作的?[...]flask 如何告诉保持 TCP 连接的操作系统将其用于其他请求?

    通常,一旦 TCP 连接打开,它就会保持打开状态,除非进程故意关闭它(或者除非它退出,在这种情况下操作系统会关闭连接)。操作系统不跟踪“请求”——这是应用程序问题;TCP可以随时向任何方向传输数据。

    所以整个HTTP/1.1“keep-alive”机制是服务器在响应发送后实际上并没有关闭TCP连接,即它没有调用shutdown()或close()。这允许客户端通过该连接发送更多 HTTP 请求。没有什么别的了——客户端和服务器都没有做任何努力来保持连接活跃,他们只是避免一开始就终止它。

    (有一个可选的 HTTP标头允许 HTTP/1.0 客户端请求保持活动,或 HTTP/1.1 客户端阻止它。)

    当然,该机制仅适用于在请求之间保持运行(并保持 OS 套接字打开)的客户端。例如,可以为curl或wgetCLI 工具提供多个 URL 以供下载,并且在为第一个 URL 建立连接后,它们将为下一个 URL 保持打开状态(假设它来自同一服务器)。但是一旦工具退出,连接总是会关闭——curl第二次运行必须建立一个全新的连接。

    类似地,Python将使用“keep-alive”在多个or调用requests.Session()中自动重用连接。但是,如果脚本退出,则连接将随之关闭。.get().post()

    但是请注意,其他一些协议也具有“保持活动”功能,其工作方式不同,通过发送明确的“我仍在运行”数据包(例如,可能每分钟发送一个保持活动数据包)。这可以通过以下两种方式之一完成 - 数据包携带应用程序生成的实际数据,或者它们是应用程序启用此功能后操作系统发送的 0 长度 TCP 数据包。(后者被称为“TCP keepalives”;它们不需要保持两台主机之间的正常连接打开,但它们有时用于防止中间系统——比如你的家庭 NAT 路由器——强行关闭它。)

    • 1

相关问题

  • 在 1Gpbs 网络中看不到传输

  • TCP Server 和 Client 会在哪个细节步骤消耗资源?[关闭]

  • 可控制 SYN、ACK、FIN 的简单 TCP 客户端

  • MSSQL 对链接服务器的高频查询出现间歇性 TCP 连接错误(连接池相关?)

  • 客户端未响应 TCP SYN-ACK 数据包以太网驱动程序

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    如何减少“vmmem”进程的消耗?

    • 11 个回答
  • Marko Smith

    从 Microsoft Stream 下载视频

    • 4 个回答
  • Marko Smith

    Google Chrome DevTools 无法解析 SourceMap:chrome-extension

    • 6 个回答
  • Marko Smith

    Windows 照片查看器因为内存不足而无法运行?

    • 5 个回答
  • Marko Smith

    支持结束后如何激活 WindowsXP?

    • 6 个回答
  • Marko Smith

    远程桌面间歇性冻结

    • 7 个回答
  • Marko Smith

    子网掩码 /32 是什么意思?

    • 6 个回答
  • Marko Smith

    鼠标指针在 Windows 中按下的箭头键上移动?

    • 1 个回答
  • Marko Smith

    VirtualBox 无法以 VERR_NEM_VM_CREATE_FAILED 启动

    • 8 个回答
  • Marko Smith

    应用程序不会出现在 MacBook 的摄像头和麦克风隐私设置中

    • 5 个回答
  • Martin Hope
    Saaru Lindestøkke 为什么使用 Python 的 tar 库时 tar.xz 文件比 macOS tar 小 15 倍? 2021-03-14 09:37:48 +0800 CST
  • Martin Hope
    CiaranWelsh 如何减少“vmmem”进程的消耗? 2020-06-10 02:06:58 +0800 CST
  • Martin Hope
    Jim Windows 10 搜索未加载,显示空白窗口 2020-02-06 03:28:26 +0800 CST
  • Martin Hope
    v15 为什么通过电缆(同轴电缆)的千兆位/秒 Internet 连接不能像光纤一样提供对称速度? 2020-01-25 08:53:31 +0800 CST
  • Martin Hope
    andre_ss6 远程桌面间歇性冻结 2019-09-11 12:56:40 +0800 CST
  • Martin Hope
    Riley Carney 为什么在 URL 后面加一个点会删除登录信息? 2019-08-06 10:59:24 +0800 CST
  • Martin Hope
    zdimension 鼠标指针在 Windows 中按下的箭头键上移动? 2019-08-04 06:39:57 +0800 CST
  • Martin Hope
    jonsca 我所有的 Firefox 附加组件突然被禁用了,我该如何重新启用它们? 2019-05-04 17:58:52 +0800 CST
  • Martin Hope
    MCK 是否可以使用文本创建二维码? 2019-04-02 06:32:14 +0800 CST
  • Martin Hope
    SoniEx2 更改 git init 默认分支名称 2019-04-01 06:16:56 +0800 CST

热门标签

windows-10 linux windows microsoft-excel networking ubuntu worksheet-function bash command-line hard-drive

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve