curl 分析 请求时长

转载链接: https://cizixs.com/2017/04/11/use-curl-to-analyze-request/

最近工作中遇到一个问题,某个请求的响应特别慢,因此我就希望有一种方法能够分析到底请求的哪一步耗时比较长,好进一步找到问题的原因。在网络上搜索了一下,发现了一个非常好用的方法,curl 命令就能帮你分析请求的各个部分耗时。

curl 命令提供了 -w 参数,这个参数在 manpage 是这样解释的:

 -w, --write-out <format>
              Make curl display information on stdout after a completed transfer. The format is a string that may contain plain text mixed with any number of variables. The  format
              can  be  specified  as  a literal "string", or you can have curl read the format from a file with "@filename" and to tell curl to read the format from stdin you write
              "@-".

              The variables present in the output format will be substituted by the value or text that curl thinks fit, as described below. All variables are specified  as  %{vari‐
              able_name} and to output a normal % you just write them as %%. You can output a newline by using \n, a carriage return with \r and a tab space with \t.

它能够按照指定的格式打印某些信息,里面可以使用某些特定的变量,而且支持 \n\t和 \r转义字符。提供的变量很多,比如 status_codelocal_portsize_download 等等,这篇文章我们只关注和请求时间有关的变量(以 time_ 开头的变量)。

先往文本文件 curl-format.txt 写入下面的内容:

➜  ~ cat curl-format.txt
    time_namelookup:  %{time_namelookup}\n
       time_connect:  %{time_connect}\n
    time_appconnect:  %{time_appconnect}\n
      time_redirect:  %{time_redirect}\n
   time_pretransfer:  %{time_pretransfer}\n
 time_starttransfer:  %{time_starttransfer}\n
                    ----------\n
         time_total:  %{time_total}\n

那么这些变量都是什么意思呢?我解释一下:

  • time_namelookup:DNS 域名解析的时候,就是把 https://zhihu.com 转换成 ip 地址的过程
  • time_connect:TCP 连接建立的时间,就是三次握手的时间
  • time_appconnect:SSL/SSH 等上层协议建立连接的时间,比如 connect/handshake 的时间
  • time_redirect:从开始到最后一个请求事务的时间
  • time_pretransfer:从请求开始到响应开始传输的时间
  • time_starttransfer:从请求开始到第一个字节将要传输的时间
  • time_total:这次请求花费的全部时间

我们先看看一个简单的请求,没有重定向,也没有 SSL 协议的时间:

➜  ~ curl -w "@curl-format.txt" -o /dev/null -s -L "http://cizixs.com"
    time_namelookup:  0.012
       time_connect:  0.227
    time_appconnect:  0.000
      time_redirect:  0.000
   time_pretransfer:  0.227
 time_starttransfer:  0.443
                    ----------
         time_total:  0.867

可以看到这次请求各个步骤的时间都打印出来了,每个数字的单位都是秒(seconds),这样可以分析哪一步比较耗时,方便定位问题。这个命令各个参数的意义:

  • -w:从文件中读取要打印信息的格式
  • -o /dev/null:把响应的内容丢弃,因为我们这里并不关心它,只关心请求的耗时情况
  • -s:不要打印进度条

从这个输出,我们可以算出各个步骤的时间:

  • DNS 查询:12ms
  • TCP 连接时间:pretransfter(227) - namelookup(12) = 215ms
  • 服务器处理时间:starttransfter(443) - pretransfer(227) = 216ms
  • 内容传输时间:total(867) - starttransfer(443) = 424ms

来个比较复杂的,访问某度首页,带有中间有重定向和 SSL 协议:

➜  ~ curl -w "@curl-format.txt" -o /dev/null -s -L "https://baidu.com"
    time_namelookup:  0.012
       time_connect:  0.018
    time_appconnect:  0.328
      time_redirect:  0.356
   time_pretransfer:  0.018
 time_starttransfer:  0.027
                    ----------
         time_total:  0.384

可以看到 time_appconnect 和 time_redirect 都不是 0 了,其中 SSL 协议处理时间为 328-18=310ms。而且 pretransfer 和 starttransfer 的时间都缩短了,这是重定向之后请求的时间。

参考资料

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: C语言的CURL库是常用的网络传输工具,它可以发送HTTP请求和接收服务器响应。在使用CURL进行POST请求时,可以通过设置回调函数来利用多线程实现并发请求。通过这种方式,可以大大提高程序的效率和响应速度。 具体实现方式可以通过以下步骤: 1. 定义一个包含POST参数的结构体,并为每个线程设置不同的结构体。 2. 在每个线程中,使用CURL的easy_init()函数初始化一个easy_handle,并使用curl_easy_setopt()函数设置POST参数、请求地址等选项。 3. 设置一个回调函数,用于处理从服务器返回的数据,并将处理结果存储起来。 4. 开始并发请求,每个线程分别执行curl_easy_perform()函数发送请求,并等待服务器响应。 5. 所有请求完成后,处理所有线程收集到的数据。 需要注意的是,如果并发请求的数量太大,服务器可能会出现过载的情况,需要合理控制线程数和请求数。 除此之外,还需要注意线程安全的问题。由于多个线程会同时操作同一个easy_handle,容易出现竞争条件和数据不一致的情况。需要通过线程锁等机制来解决这些问题,保证程序的正确性。 总之,通过利用CURL库和多线程技术,可以实现高效的并发POST请求。这对于需要频繁向服务器发送请求的程序来说,是非常有意义的优化。 ### 回答2: cURL是一个强大的命令行工具,可以用来发送HTTP请求。它支持多种协议,包括HTTP、HTTPS、FTP等。 使用cURL进行post并发请求,可以通过以下步骤实现: 1. 创建一个cURL句柄,设置请求的URL,请求方法为POST,并设置POST数据。 2. 将cURL句柄加入到multi_handle中,使用curl_multi_add_handle函数。 3. 使用curl_multi_perform函数启动请求。 4. 使用curl_multi_info_read函数读取请求的返回信息,判断请求是否完成。 5. 如果请求未完成,则继续调用curl_multi_perform函数。 6. 如果请求已完成,则使用curl_multi_remove_handle函数将cURL句柄从multi_handle中删除。 7. 释放cURL句柄和multi_handle。 在并发请求中,可以设置多个cURL句柄,将它们加入到multi_handle中,同时启动多个请求。这样可以提高请求的效率。 需要注意的是,使用cURL进行并发请求时,必须设置超时时间,以避免请求长时间卡在某个请求上,导致整个请求堵塞。 总的来说,使用cURL进行post并发请求,可以有效提高请求效率,减少请求时间。但同时也需要注意并发数的控制,避免产生过多的网络请求,影响系统稳定性。 ### 回答3: curl是一种命令行工具和一个库,可以用于发送和接收HTTP请求,支持各种协议和数据传输方式。使用curl可以简单快速地进行HTTP请求,并发请求则可以提高请求效率。 在C语言中,可以使用curl库来进行HTTP请求,使用curl_easy_setopt函数设置请求选项,然后使用curl_easy_perform函数执行请求。要进行并发请求,可以使用curl_multi_init函数初始化multi curl对象,然后使用curl_multi_add_handle函数将多个curl_easy句柄添加到multi curl对象中。最后使用curl_multi_perform函数执行并发请求。 在进行curl并发请求时需要注意以下几点: - 需要使用multi curl对象来进行并发请求,单个curl_easy句柄不支持并发请求。 - 在设置请求选项时,需要使用curl_easy_setopt设置多个选项,如CURLOPT_URL、CURLOPT_POST、CURLOPT_POSTFIELDS等。 - 在执行并发请求时,需要使用curl_multi_perform函数。此函数会异步执行所有添加到multi curl对象中的请求,并等待所有请求完成。 - 可以使用curl_multi_info_read函数来获取已完成的请求信息,如响应状态码、响应头信息等。 需要注意的是,并发请求可能会产生并发问题,如资源竞争、内存泄漏等。因此,需要仔细设计并发请求的逻辑,处理好多线程之间的同步和互斥问题,以保证程序的稳定性和效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值