最近遇到联通免流问题,整理了下解决问题过程、思考、debug网络数据,与大家分享,有不对的地方欢迎大家指出。
联通免流bug
修复前的设计:
- ProcessA负责读写是否使用代理。
- ProcessA进程把是否代理存储到本地文件中。
- ProcessA通过AIDL调用ProcessB接口通知更新代理状态,通过参数告诉ProcessB是否使用代理。
注:应用是多进程的,ProcessA是主进程,ProcessB是后台进程(如播放歌曲之类的在本进程播放)。
设计缺陷
- Wifi网络下,ProcessA退出后,ProcessB还在运行时,切换网络到3G/4G,ProcessB中的网络请求就没有走代理。
- 如果ProcessA不在时,就没人通知ProcessB进行更新是否使用代理。
注:夸进程数据没有同步导致问题的。
解决方案:
- 是否代理存储在哪里无所谓(数据库、文件、SharePreference等等)。
- 监听文件数据改变。
总结:一个进程负责写数据;另外进程只读数据,且注册监听数据变化。
思考
联通免流bug,实际上是一个关于多进程数据同步问题,多进程需要做到数据同步实现方式如下:
1. 数据