记一次线上大量close_wait

一个简单的微信小项目在上线后由于大量用户访问首页投票导致崩溃。问题源于定位接口的HTTP请求未进行正确关闭,导致大量CLOSE_WAIT状态。通过查看错误日志和TCP/IP监控,发现接口代码中httpUtil方法缺少finally块的close操作。修复此问题后,close_wait状态消失,项目恢复正常。该案例强调了细致检查和正确管理HTTP连接的重要性。
摘要由CSDN通过智能技术生成

背景:

一个微信的小项目。项目很简单,只有定位、投票、分享、排名、留言等功能。


 

当上线开始,大量用户访问首页投票。没过1分钟项目立马崩了。

马上排查错误原因。

  1. 查看错误日志,因未打印详细日志,未查到有价值信息。
  2. 查看TCP/IP监控。输入 netstat -apn|grep 8080 看到如下信息。

大量的CLOSE_WAIT。

因为首页只有一个定位接口,获取用户位置信息。微信获取位置信息需要发送http请求获取签名。

此时检查对应代码发现,httpUtil方法finally里并未close操作。这样就很明确了。立马修改代码。

发布后验证发现close_wait消失。 

总结:网上找util方法一定要仔细检查,否则坑死你。

服务器端大量close_wait状态通常是由于服务器程序没有正确地关闭网络连接导致的。为了解决这个问题,可以采取以下几种方法: 1. 关闭连接前确保双方都关闭了连接:在服务器程序中,确保在关闭连接之前发送一个关闭请求给客户端,要求其关闭连接。这样可以避免服务器端出现大量close_wait状态。 2. 设置合适的超时时间:在服务器程序中,为每个网络连接设置一个合适的超时时间。如果连接在超过一定时间内没有活动,那么服务器可以主动关闭连接,避免出现close_wait状态。 3. 使用连接池管理连接:通过使用连接池管理服务器和客户端之间的连接,能够更好地控制连接的创建和关闭。在每个连接使用完毕后,将其放回连接池中,而不是立即关闭。这样可以避免频繁创建和关闭连接,减少close_wait状态的产生。 4. 检查服务器程序的bug:关闭连接后产生大量close_wait状态可能是服务器程序中存在的bug导致的。检查服务器程序的代码,确保在每个连接关闭的地方都正确处理了关闭连接的操作,避免出现资源泄漏问题。 综上所述,解决服务器端大量close_wait状态的问题需要深入分析服务器程序的代码和连接管理机制,确保连接在合适的时候被关闭,避免出现close_wait状态。同时,合理设置超时时间和使用连接池等方法也可以减少close_wait状态的产生。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

winx96

谢大哥~

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值