• libcurl底层调用逻辑


    libcurl就不多介绍了,一个支持HTTP,FTP,SMTP等协议的网络库

    只涉及multi部分,easy部分就不提了。

    两个线程,一个负责添加HTTP请求,另一个轮询,负责处理每一个请求

    Thread 1:

    初始化一次multi_handle,每次Request在分别初始化easy_handle

    curl_multi_add_handle(CURLM *multi_handle,CURL *easy_handle),将easy_handle添加到multi的队列,完事。

    Thread 2:

    select(maxfd , &fdread, &fdwrite, &fdexcep, &timeout),等待有读写时间发生

    curl_multi_perform:

        while(Not Empty){

            multi_runsingle:最主要的函数,做的事情有:1.DNS解析, 2.TCP连接, 3.SSL握手, 4.Protocol Switch(Http2), 5.发送请求, 6接受数据

             其中两个状态最重要:

             CURLM_STATE_DO: curl_do, Prepare HTTP Request frame and send it out.

             CURLM_STATE_PERFORM: Curl_readwrite,等待发送完成,然后继续等待接受完成

                              multi_runsingle出来,就表示一次HTTP Request的收发就结束了。

        }

    msg = curl_multi_info_read(m_curlMultiHandle, &messagesInQueue);拿到msg,可以分析状态、性能等...

  • 相关阅读:
    文本特殊符号汇集
    十大编程算法助程序员走上高手之路
    单例模式(Singleton)
    flink time and watermark
    关于maven依赖关系的问题
    幂等
    乐观锁和悲观锁的一个例子
    Elasticsearch logstash filter
    ELK filebeat的安装
    使用 Python 验证数据集中的体温是否符合正态分布
  • 原文地址:https://www.cnblogs.com/zzSoftware/p/3782900.html
Copyright © 2020-2023  润新知