Java通讯程序总结

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

你可能感兴趣的:(java,jvm,多线程,weblogic)