tshark
tshark -V -O http -Y “(http.request and http.host contains ymatou)” -T fields -e frame.number -e http.request.method -e http.request.full_uri -r ~/workspace/python/osx/lele/ymt-addproductv2.pcapng
FILTER FIELD REFERENCE
tshark -G fields on the command line
Troubleshooting
SSL123
Starting with Wireshark 2.0, the RSA key file is automatically matched against the public key as found in the Certificate handshake message. Before Wireshark 2.0, it relied on the user to enter a valid Address and Port value. Note that only RSA key exchanges can be decrypted using this RSA private key, Diffie-Hellman key exchanges cannot be decrypted using a RSA key file! (See “SSLKEYLOGFILE” if you have such a capture.)
连接建立的时候, 会告诉你是否采用Diffie Hellman key交换, 这样的方式你只能采用SSLKEYLOGFILE方式
抓不到应该出现的包
路由问题,路由问题,路由问题
重要的事情说三遍, 仔细检查路由表, 看看是否路由正确, 网络配置错误很容易导致.
关于tcp segment len超过1500
很可能是网卡支持tso, 同时打开了该功能, 应用层的拆包工作交给了网卡, 一般这种情况, 你能在对端看到正确的tcp segment len大小
TCP Full Window
The Receiver advertises a TCP Window of 5000 byte. The Sender sends 5 packets with a TCP Len of 1000 each There is no ACK between those 5 packets Wireshark will mark the 5th packet with [TCP Window Full] as it has seen those advertized 5000 bytes, without an ACK
SACK
下面是一个wireshark包截图
截图信息显示,接收端希望接受的下一个包的sequence号是16953,但是它已经收到了18413~22793的包了,没有接收到16953~18412,发送端可以根据这个ack,重传16953~18412。
参考连接TCP Selective Acknowledgments (SACK)
如何查找一个session
标识一个tcp链接通过src_ip:port -> dst_ip:port, 过滤条件写上就行, 当然tcp port存在重用的情况, 所以你还需要加上session id啥的, 在cookie里面有
Usage
导出过滤的包
首先过滤包, 然后file -> export specified packets -> all packets 也可以通过tshark来过滤, 一般可以
LUA
httpext.lua
案例
session失效
系统做了单点登录,用的是CAS,用户反馈偶尔系统登出之后,重新用其他帐号登入,查询 到的用户资料依然是上一个用户的,只有关闭浏览器之后,才能正常。
从直观上判断,应该是session问题,询问了一下应用开发人员,确认用户id存放在session 中。只有为啥session没有销毁成功,简单做法就是抓包分析。
先是用wireshark在客户端做了分析,发现在出现问题的时候,系统去请求出现问题的页面 不会做跳转(初次访问该页面需要去cas登入),也就是说对于业务系统来说,jsessionid 依然有效。
了解了一下cas的原理:用户去portal平台做登入,从cas获取到TGT。第一次访问业务模块 的时候,由于没有session,会创建一个session,然后重定向到sso做登入。而注销的时候 cas负责销毁创建的session。从故障看,问题就是出现在销毁session上。
通过tcpdump来抓包: sso服务器端:
[root@localhost ~]# tcpdump -p -nn -s 0 tcp port 8088 and host 172.16.102.205 -w sso.dump
tcpdump: listening on eth0, link-type EN10MB (Ethernet), capture size 65535 bytes
应用端:
[root@trust-test-app ~]# tcpdump -p -nn -s 0 host 172.17.102.106 and not tcp port 8001 -w sso-logout.dump
tcpdump: listening on eth0, link-type EN10MB (Ethernet), capture size 65535 bytes
用wireshark分析包,可以看到CAS发出去的销毁session请求被reset,查看了一下环境,问 题出现在apache上,询问了一下,apache是自己编译的,而且配置文件也是乱七八糟,没想 明白为啥被reset而不是connection reject之类的,修改apache配置问题解决。
当然也不能算彻底解决,CAS关于注销的实现有bug,是一个不可靠实现,需要做一定处理。