Linux - curl -w 参数详解
-w 的作用
- 完成请求传输后,使 curl 在 stdout 上显示自定义信息
- 格式是一个字符串,可以包含纯文本和任意数量的变量
输出格式
- 输出格式中的变量会被 curl 用对应的值替换掉
- 所有变量的格式为: %{variable name}
- 要输出一个普通的 % 只需将它们写为 %%
- 可以使用 \n、带 \r 的回车符和带 \t 的制表符来输出换行符
- 如果想通过文件来传入变量,可以用 @filename 的格式
变量列表
content_type(有用)
HTTP 请求的 Content-type
errormsg(有用)
错误信息
exitcode
转移的数字出口代码,不知道啥来的
filename_effective
curl 执行结果最终写入的文件名,当加上了 -o、-O 才有意义
ftp_entry_path
初始路径,当登录到远程 FTP 服务器时结束
http_code(有用)
响应码
http_connect
在对 curl CONNECT 请求的最后响应(来自代理)中找到的数字代码
http_version
http 版本
local_ip(有用)
ip 地址,可以是ipv4,也可以是ipv6
num_connects
最近传输中,新的连接数
num_redirects
在请求中跳转的次数
redirect_url
当 curl 没有指定 -L、--location 参数跟随重定向时,此变量将显示重定向实将跳转的实际 URL
remote_ip(有用)
目标服务器的远程IP,可以是 ipv4、ipv6
remote_port(有用)
目标服务器的远程端口
response_code(有用)
和 http_code 一样,都是响应码
scheme
请求协议,就是 HTTP、HTTPS
size_download
下载的总字节数
size_header
下载头的总字节数
size_request(有用)
HTTP请求中发送的总字节数
size_upload
上传的总字节数
speed_download
平均下载速度,每秒字节数
speed_upload
平均上传速度,每秒字节数
time_namelookup(有用)
DNS 域名解析的耗时,就是把 https://zhihu.com
转换成 ip 地址的过程
time_connect(有用)
TCP 连接建立的时间,就是三次握手的时间
time_appconnect(有用)
SSL/SSH 等上层协议建立连接的时间,比如 connect/handshake 的时间
time_redirect(有用)
- 在最终事务开始之前,所有重定向步骤(包括名称查找、连接、预传输和传输)所用的时间(以秒为单位)
- time_redirect 显示多个重定向的完整执行时间
time_pretransfer(有用)
从请求开始到响应开始传输的时间
time_starttransfer(有用)
- 从请求开始到第一个字节将要传输的时间
- 包括预传输时间和服务器处理结果所需的时间。
time_total(有用)
这次请求花费的全部时间
url_effective(有用)
- 最后获取的 URL
- 如果 curl 添加了 -L 且真的重定向之后,这个就很有用了
使用 curl 命令分析请求的耗时情况
实际工作中的问题
某个请求的响应特别慢,那想要分析为什么这个请求慢,到底是哪一步耗时长,应该怎么做?
强大的 curl -w
提供了 7 种 time 变量,上面就能看到
写一个文件,包含 7 种变量,还能比较好看的格式化输出
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}
请求 http
curl -w "@format.txt" -S -s -L -k -o /dev/null http://baidu.com
所有时间都是秒单位
- DNS 解析查询时间:time_namelookup【 0.004146】
- TCP 建立连接时间:time_connect【0.013002】 - time_namelookup【0.004146】
- 服务器处理时间:time_starttransfer【0.02542】-time_pretransfer【0.013039】
- 内容传输时间:time_totle【0.072124】-time_starttransfer【0.02542】
因为不是 https 协议和重定向,所以中间两个没有时间
请求 https
curl -w "@format.txt" -S -s -L -k -o /dev/null https://baidu.com
SSL 协议处理时间:time_appconnect【0.042989】 - time_namelookup【 0.008223】
Linux - curl -w 参数详解的更多相关文章
- (转)Linux curl命令参数详解
Linux curl命令参数详解 命令:curl在Linux中curl是一个利用URL规则在命令行下工作的文件传输工具,可以说是一款很强大的http命令行工具.它支持文件的上传和下载,是综合传输工具, ...
- Linux curl命令参数详解(6/23)
linux curl是通过url语法在命令行下上传或下载文件的工具软件,它支持http,https,ftp,ftps,telnet等多种协议,常被用来抓取网页和监控Web服务器状态. 在Linux中c ...
- Linux curl命令参数详解--转载
linux curl是通过url语法在命令行下上传或下载文件的工具软件,它支持http,https,ftp,ftps,telnet等多种协议,常被用来抓取网页和监控Web服务器状态. 一.Linux ...
- Linux curl命令参数详解
笔者出处:http://www.aiezu.com/system/linux/linux_curl_syntax.html linux curl是通过url语法在命令行下上传或下载文件的工具软件,它支 ...
- linux ./configure 的参数详解
转载自http://blog.csdn.net/zjt289198457/article/details/6918656 linux ./configure 的参数详解 ./configure 该 ...
- Linux ifconfig-etho文件参数详解
1.ifcfg-eth0文件参数详解 DEVICE 网卡名称/网络接口的名称BOOTPROTO 系统启动地址协议 常用参数: none:不使用启动地址协议,none禁止DHCP bootp:BOOTP ...
- [Linux命令]curl命令参数详解——转载
linux curl是通过url语法在命令行下上传或下载文件的工具软件,它支持http,https,ftp,ftps,telnet等多种协议,常被用来抓取网页和监控Web服务器状态.curl命令参数介 ...
- curl常用参数详解及示例
curl简介 curl是一个开源的命令行工具,它基于网络协议,对指定URL进行网络传输,得到数据后不任何具体处理(如:html的渲染等),直接显示在"标准输出"(stdout)上. ...
- linux Tar 命令参数详解
tar命令 . 作用 tar命令是Unix/Linux系统中备份文件的可靠方法,几乎可以工作于任何环境中,它的使用权限是所有用户. . 格式 tar [主选项+辅选项] 文件或目录 eg: tar z ...
随机推荐
- 8、基本数据类型(dict)
8.1.字典: 1.字典元素用大括号括起来,用逗号分割每个元素,字典元素是"key:value"的形式 dic = { "k1": 'v1', #键值对 &qu ...
- Flask(7)- request 对象
Flask 中很重要的 request 对象 浏览器访问服务端时,向服务端发送请求 Flask 程序使用 request 对象描述请求信息 当你想获取请求体.请求参数.请求头数据的时候,就需要靠 re ...
- CG-CTF WxyVM2
一.原本以为要动调,因为出现了这个,函数太长,无法反编译 后面才知道这玩意可以在ida的配置文件里面去改,直接改成1024. 里面的MAXFUNSIZE改成1024,就可以反编译了,这个长度是超过这个 ...
- WPF教程七:通过App.xaml来了解Application类都能干什么
这个章节来了解Application类,我考虑了一晚上决定跳过控件类相关的学习,因为控件如果只是入门的话每个控件F12跳过去看一下属性.事件就能大致了解的差不多,而且控件比较多,每个都这样看一遍,感觉 ...
- 安装PyTorch后,又安装TensorFlow,CUDA相关问题思考
下面的话是我的观察和思考,请多多批评. TensorFlow 要用 CUDA.CUDA toolkit.CUDNN,看好版本的对应关系再安装,磨刀不误砍柴工. 1)NVIDIA Panel 里显示的N ...
- STM32中的通信协议
按照数据传送方式分: 串行通信(一条数据线.适合远距离传输)并行通信(多条数据线.成本高.抗干扰性差) 按照通信的数据同步方式分: 异步通信(以1个字符为1帧.发送与接收时钟不一致)同步通信(位同步. ...
- ARTS第十二周
1.Algorithm:每周至少做一个 leetcode 的算法题2.Review:阅读并点评至少一篇英文技术文章3.Tip:学习至少一个技术技巧4.Share:分享一篇有观点和思考的技术文章 以下是 ...
- ACM金牌选手算法讲解《线性表》
哈喽,大家好,我是编程熊,双非逆袭选手,字节跳动.旷视科技前员工,ACM亚洲区域赛金牌,保研985研究生,分享算法与数据结构.计算机学习经验,帮助大家进大厂~ 公众号:『编程熊』 文章首发于: ACM ...
- ES 基础知识点总结
为什么使用 ES? 在传统的数据库中,如果使用某列记录某件商品的标题或简介.在检索时要想使用关键词来查询某个记录,那么是很困难的,假设搜索关键词 "小米",那么 sql 语句就是 ...
- 从新建文件夹开始构建ShadowPlay Engine游戏引擎(4)
本篇序言 这次博客更新距离上次的时间间隔变短了好多,因为最近硬是抽出了一大部分时间来进行引擎的开发.而且运气很好的是在写链表这种很"敏感"的的数据结构的时候并没有出现那种灾难性的后 ...