Chinaunix

标题: 如何解决UDP服务器高并发问题? [打印本页]

作者: yu9148    时间: 2015-09-30 15:55
标题: 如何解决UDP服务器高并发问题?
最近在写一个UDP服务器,大概3W+设备连接,每秒2000条数据左右。数据报文不大,但可能需要操作数据库。

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


路过的大神们指点指点。谢谢!~~ 路过的大神们指点指点。谢谢!~~ 路过的大神们指点指点。谢谢!~~ 路过的大神们指点指点。谢谢!~~
作者: Heaven_Redsky    时间: 2015-10-06 22:14
个人建议哈,这个读线程十有八九是做了什么速度慢的操作了,比如你说的操作数据库。那我想,在这个读线程里下一些时间戳,或许能找到影响速度都节点,然后想办法优化。另一方面,如果处理的速度与接收报文的速度相差太远,或许可以将循环缓冲区的size变大一些,或者设置多个循环缓冲区,由多个读线程共同并行处理数据。
作者: yjh777    时间: 2015-10-19 16:43
就按你网络搜到的来,epoll + 线程池
作者: yu9148    时间: 2015-11-06 14:16
嗯,是的。

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




欢迎光临 Chinaunix (http://bbs.chinaunix.net/) Powered by Discuz! X3.2