zoukankan      html  css  js  c++  java
  • KendyNet性能测试

    这几天编写了一个测试程序,测试我的网络库(KendyNet for Windows)的性能,主要用于模拟大量玩家在同一区域内,

    互相可见情况下网络的压力情况.

    测试环境:

    客户机和服务器 E5520 4GB windows 2008 server

    千兆网.

    客户机启动一个进程,建立360个连接到服务器,模拟360个客户端,每个客户端每秒发送16个28字节的封包,服务器

    收到每个封包都将其转发给所有的360个客户端.

    处理能力是每秒接收6000+,转发220W+,CPU占满单个核心,内存占用8M左右,封包一个来回的平均延时在46ms左右.

    这已经达到了最大处理能力,再加连接就开始导致性能下降,内存消耗暴增.

    https://github.com/sniperHW/KendyNet/tree/master/IOCP

    可以取得测试代码,需要注意的是,请将winsock2.h中的FD_SETSIZE从64改成1024,另外因为使用了

    SetFileCompletionNotificationModes所以在xp,和windows 2003上是无法运行测试程序的 。

    后面将会着手编写KendyNet for linux的测试程序.

     (2012-5-19,做了点优化,将wpacket_t和rpacket_t的产生从malloc换成对象池,目前可以稳定支持420个客户端,每秒转发290W个包,

    当玩家超过450时,转发量达到340W并维持了一段时间(大概一两分钟),cpu 13%,已经占满单个核心,服务器逐渐处理不过来,延时变大,很快对象池空间耗尽。)

  • 相关阅读:
    keepass
    gpg
    Wireshark实践
    ssh
    namp
    第十二周
    第十一周
    第十周总结
    第九周学习总结
    编程语言
  • 原文地址:https://www.cnblogs.com/sniperHW/p/2506875.html
Copyright © 2011-2022 走看看