使用Socket开发http服务器时碰到的问题及处理方法
1. 前言
最近正在为QA测试开发压力测试框架,要为测试人员提供一个结果的图形化表示界面。为了展示数据的及时性,不得不使用lua语言实现一个http服务器。由于http服务需要提供的服务比较简单 ,并且lua并没有能够很好的与压测框架结合的简单易用的http库,于是着手使用压测框架使用的基础框架提供的针对http服务的socket封装开发。
2. 问题
在实现了一个简单的静态文件服务器后,我对其进行了初步的测试,发现了一个很严重的问题:浏览器在成功请求到html文件后,解析html文件,请求html中需要的静态资源时,总是在请求6个资源成功后无法继续请求。
3. 原因
经过一段不短时间的排查,我最终定位到了问题所在:基础框架提供的socket封装中,socket监听函数每次监听到新的请求时,即分配一个新的socketId,库中维护了一个socketPool。我在返回请求结果后,没有释放占用的socket,导致监听函数在监听到新的请求时,没有可用的socketId,即阻塞整个服务,导致浏览器请求失败。
4. 解决方法
在服务成功响应请求,并发送成功后,释放占用的socket,保持socketPool中有可用的资源。