Java通讯程序总结

近期使用netty编写Java通讯程序终于告一段落。程序用来接收DTU上传的报文并进行解析入库,由于现场设备较多,同时要求在线率要保持在98%以上,对于程序的处理能力很是考验。
最初的设计没有考虑那么多,而且对于netty也不是很熟,把报文处理和数据入库写在一起了。后来压力测试发现处理能力极低,只有50-60条/秒,虽然在目前现场5000台设备的情况下也够用了,但是对于这个性能还是不能满意。尤其是高并发的情况下将极大的影响在线率。
通过跟踪发现数据库操作是整个系统的性能瓶颈,于是将报文处理与数据入库分开来,利用线程池来处理入库操作,同时设置了JVM的启动参数。通过几天的监控跟踪,发现大大提高了性能,基本能稳定在400条/秒。但是还是有丢包的现象,这就说明在网络并发方面还是有提高的可能性。
在一个偶然的机会下,发现HotSPot和JRockit居然有很大的不同,尤其在网络处理方面(有两台服务器,一台装了weblogic,就用了JRockit,另一台装了HotSPot)。在使用了JRockit后发现处理能力可以稳定在1000条/秒不丢包。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值