时间来到去年底 。当前这个项目进行压力测试,发现关键的语音处理服务运行一段时间后,会出现不拉流的情况,因此也没有后续的结果输出 。症状和上一个项目非常像 。虽然使用的第三方SDK不一样,但同样用了go和c混编的方式 。一开始,焦点就放在go的运行时上,觉得可能是go和c相互调用的方式不对 。经过合理猜测,并用测试进行验证后,发现问题还是在第三方拉流的SDK上,它们的回调函数必须要快,否则有可能会阻塞它们的回调线程 。当然,在go调用c的时候,如果耗时比较长,会对go的运行时造成一些副作用;在c回调go的时候,go的运行时也有可能阻塞c的回调线程 。但go的运行时已经比较成熟,因此我觉得它对这个问题的贡献不大 。以上采用了假设-验证的方法,主要的原因还是第三方的拉流SDK不开源 。在定位问题的过程中,使用了gdb的gcore来生成堆栈;也搭建了灰度环境来进行压力测试,以及完善监控,这些都是解决方法的一部分 。
正是这一问题,促使我更多的了解go的运行时 。而我看得越多,越觉得go的运行时是一个庞大的怪物 。因此,抱着能了解一点是一点的心态,不断的完善这篇笔记 。
秒懂生活扩展阅读
- 教师培训有那些好处
- 嵌入式培训班有必要吗 嵌入式学习
- 企业培训是否需要前置审批
- 市场培训督导具体工作是做什么的
- 广州哪个西点面包培训学校好些
- 什么是TTT培训师培训
- 网上编程培训哪家好 编程学习
- gre培训师 gre培训
- u3d培训 u3d
- 游戏测试培训学校有哪些