免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3977 | 回复: 3

[网络] 如何解决UDP服务器高并发问题? [复制链接]

论坛徽章:
0
发表于 2015-09-30 15:55 |显示全部楼层
最近在写一个UDP服务器,大概3W+设备连接,每秒2000条数据左右。数据报文不大,但可能需要操作数据库。

现在遇到下面几个问题,路过的大神们指点指点。谢谢!~~
   
     1. 如何解决UDP服务器的并发问题?
        ---看网上许多用epoll+线程池解决TCP服务器并发,UDP是否适用啊?
     2. 现在一个接收线程接收到数据存入缓冲大数组,另一个读线程读出解析,但是大并发的时候读线程处理不过来,数据在缓冲区累积。
         怎样能提高这个读线程的处理速度呢??


路过的大神们指点指点。谢谢!~~ 路过的大神们指点指点。谢谢!~~ 路过的大神们指点指点。谢谢!~~ 路过的大神们指点指点。谢谢!~~

论坛徽章:
0
发表于 2015-10-06 22:14 |显示全部楼层
个人建议哈,这个读线程十有八九是做了什么速度慢的操作了,比如你说的操作数据库。那我想,在这个读线程里下一些时间戳,或许能找到影响速度都节点,然后想办法优化。另一方面,如果处理的速度与接收报文的速度相差太远,或许可以将循环缓冲区的size变大一些,或者设置多个循环缓冲区,由多个读线程共同并行处理数据。

论坛徽章:
84
每日论坛发贴之星
日期:2015-12-29 06:20:00每日论坛发贴之星
日期:2016-01-16 06:20:00每周论坛发贴之星
日期:2016-01-17 22:22:00程序设计版块每日发帖之星
日期:2016-01-20 06:20:00每日论坛发贴之星
日期:2016-01-20 06:20:00程序设计版块每日发帖之星
日期:2016-01-21 06:20:00每日论坛发贴之星
日期:2016-01-21 06:20:00程序设计版块每日发帖之星
日期:2016-01-23 06:20:00程序设计版块每日发帖之星
日期:2016-01-31 06:20:00数据库技术版块每日发帖之星
日期:2016-01-16 06:20:00程序设计版块每日发帖之星
日期:2016-01-16 06:20:00程序设计版块每日发帖之星
日期:2016-01-14 06:20:00
发表于 2015-10-19 16:43 |显示全部楼层
就按你网络搜到的来,epoll + 线程池

论坛徽章:
0
发表于 2015-11-06 14:16 |显示全部楼层
嗯,是的。

确实读线程操作数据库导致处理数度变慢了,后来把接收的数据放入队列里,开了两个线程来并行处理,基本满足那个条件了。 后面不行再改其他的方法吧。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP