iOS 下如何一键调试 Push

来湾区工做的一项有趣之处,是能够和来自彻底不一样工程文化背景的程序员们碰撞交流,语言习惯,教育环境,思惟模式,工程经验都存在不小的差别。来湾区半年有余,这段时间下来有一点我感觉颇深,这边的程序员很是强调作一件事的效率。在遇到一个有挑战性的项目时,前期的设计讨论调整很是频繁以求最优路径抵达目标,日常作项目时,各个程序员都有本身的工具箱和小脚原本应付各种场景。目的是都花最少许的时间干最多的活,又或者是为了避免加班 :)程序员

闲话不提,这篇文章和你们分享一个我以前调试 APN 的方式。vim

场景:测试又又又发现收不到 Push 了

测试同窗每隔一段时间就会发现 iPhone 又收不到 Push 了,这是常常发生在上家公司的场景(湾区好像不少公司都没测试),最后调试下来缘由各不相同,但每次都免不了停下手头的工做走一遍流程:数据线连手机,查看 uuid,启动虚拟网卡,运行 WireShark 或者 tcpdump 抓包,排除 server 端问题,查看手机设置。等定位好问题至少已过去十多分钟,白白浪费的十多分钟。上述场景发生过几回以后,我写了个简单的小工具来应对。bash

问题:如何提高效率

我但愿能将网络抓包这一流程尽量简化,首先调试定位是不是 Apple 服务器没有发送 Push,最好能一键完成操做。用脚本一步步来实现。服务器

第一步,连上测试 iPhone 以后,自动获取 uuid网络

咱们能够在 terminal 用 system profiler 命令来获取链接 mac 的 usb 设备:socket

system_profiler SPUSBDataType
复制代码

system_profiler 是一个用来获取当前系统软硬件配置信息的命令,能够经过 man system_profiler 查看详细使用方法。上述命令执行结果以下:tcp

能够清楚看到经过 usb 链接的 iPhone udid 数据(Serial Number),咱们用 sed 提取出目标信息便可:工具

system_profiler SPUSBDataType | sed -n -E 's/Serial Number: (.+)/\1/1p'
复制代码

我只提取了第一个匹配结果,由于我通常只会经过 usb 连一个 iOS 设备。测试

第二步,建立虚拟网卡以便抓包ui

咱们只须要将上面提取的设备 udid 做为参数传人建立网卡命令:

system_profiler SPUSBDataType | sed -n -E 's/Serial Number: (.+)/\1/1p' | xargs rvictl -s
复制代码

执行完上述命令,应该能看到以下输出:

Starting device 198a630825ee39496411dc3e323039f2947fa16f [SUCCEEDED] with interface rvi0
复制代码

第三步,启动 tcpdump 监控虚拟网卡

同理,咱们只须要等 rvictl 命令执行完毕以后,启动 tcpdump 便可。从第二步的输出里知道虚拟网卡的 id 为 rvi0,因此咱们将命令修改以下:

system_profiler SPUSBDataType | sed -n -E 's/Serial Number: (.+)/\1/1p' | xargs rvictl -s | sudo tcpdump -i rvi0
复制代码

首次 sudo tcpdump 的时候会须要输入管理员密码,若是一切正常,那么会看到以下输出:

tcpdump: WARNING: rvi0: That device doesn't support promiscuous mode (BIOCPROMISC: Operation not supported on socket) tcpdump: verbose output suppressed, use -v or -vv for full protocol decode listening on rvi0, link-type PKTAP (Apple DLT_PKTAP), capture size 262144 bytes 复制代码

第四步,调整参数

虽然咱们已经启动了抓包流程,但咱们的目标是调试 push,因此咱们只对 APN 过来的网络包感兴趣,接下来要对 tcpdump 增长包的 filter,设置一些简单参数。

这里须要一点对 iOS APN 相关的了解,据我分析 APN 的数据通道状况是:在 iOS 9 以前,Apple 有一个专门的长连接通道来推送应用的 push,并且端口号固定在 5223。从 iOS 9 开始,Apple 开始采用 HTTP 2.0,新建了一个综合用处的 HTTP 2.0 长连接通道,这个综合通道应该不止会推送 Push,因此抓包的时候会看到包的数量多于以前的 5223 通道。现状是:Apple 在新版系统里同时用了两个通道,因此 APN 有时候走 5223,有时候又是走 HTTP 2.0,策略不明。

简单分析以后,目标明确,咱们只须要对端口作限制便可。HTTP 2.0 毫无疑问会用 HTTPS,端口是走 443,因此咱们最后的命令调整以下:

system_profiler SPUSBDataType | sed -n -E 's/Serial Number: (.+)/\1/1p' | xargs rvictl -s | sudo tcpdump -i rvi0 src port 5223 or https
复制代码

第五步,快捷启动

咱们不可能每次都敲一边上面这一长串命令,为了操做方便,咱们能够给命令加个 alias,编辑 .bash_profile:

vim ~/.bash_profile
复制代码

加入命令别名:

alias apn="system_profiler SPUSBDataType | sed -n -E 's/Serial Number: (.+)/\1/1p' | xargs rvictl -s | sudo tcpdump -i rvi0 src port 5223 or https"
复制代码

启用配置

source ~/.bash_profile
复制代码

第六步,验收成果

下次测试同窗再来调试 Push 收不到的问题,插上 USB 以后,我只须要:

1 按 F2 启动 Terminal(我 Mac 系统经过 BetterTouchTool 设置的快捷键)

2 输入 apn 回车

Bingo,接下来就能够喝口咖啡,安安静静看包了。

总结

上面的脚本只是将一些小工具结合利用,就能起到节约时间精力的疗效,开发过程当中相似的例子有不少,总有一些工具或途径能提高咱们的开发效率,多思考就有收获,你们在日常工做时也能够多琢磨下怎么利用工具提升生产力。

因为 FB 确实不用加班,个人空余时间忽然多了起来,因此计划着今年多更新点文章。文章的重点会放在思路心得分享上,以短篇好消化为主。相似这篇文章目的在于分享用工具提高效率节约时间的思想。

相关文章
相关标签/搜索