当前位置:  技术问答>linux和unix

********************使用io复用好还是多线程的性能好?**************************

    来源: 互联网  发布时间:2015-03-20

    本文导语:  做一个并发网络服务器。大概并发客户数目在2000以上。现请问 这个网络服务器是使用io 复用(select)处理客户请求好,还是给每个客户分配一个处理线程性能更好? 另外,Linux进程最大线程数和最大能打开的文件描...

做一个并发网络服务器。大概并发客户数目在2000以上。现请问
这个网络服务器是使用io 复用(select)处理客户请求好,还是给每个客户分配一个处理线程性能更好?


另外,Linux进程最大线程数和最大能打开的文件描述符数如何进行修改?
套节口select最大支持多少个套节口句柄而不影响性能?

请有经验的多多指点。没有经验的请不要误导在下。

|
如果你是但cpu且进行请求操作时没有阻塞调用(包括写盘),用select
其他建议用多线程或多进程,使用多线程不是滥用多线程!!!
还可以将两者结合,用io 复用(select)接受数据,交由某个线程进行相应的处理和相应

|
我想说明的一点是数据库应该不会考虑支持如此多的连接
数据库也是文件系统
我觉得数据库这一部分,应该采取连接次的办法来开发

|
IO复用如果fd多于1000个的话 可以考虑用epoll的patch

|
个人感觉哦,应该是IO多路转接加非阻塞IO+工作线程。
工作线程和侦听线程分开为多个进程里。(用线程的话,考虑到安全性和稳定性,要和守护进程分开。)
通过描述字传递来完成它们之间的通信。


|
并发数到2000的时候很多事情都很难说了,
我还没有见过单台oracle的并发连接数超过500
给个建议,你可以试试装个apache做压力测
试看看并发连接数到2000左右的时候,系统的
负荷情况。

|
一个现实的多进程服务器是BBS系统,一塌糊涂BBS用dual PIII 866 + 4G内存支持了接近9千
的在线用户,一般来说load峰值不超过3,平均保持在1上下,用的是多进程。但是我觉得如
果用epoll的patch,改用单进程的IO,性能会更好。

|
poll的问题在于它的算法复杂度是n,就是说每次都要从n个描述符中选出一个,而请求
也是n,所以总的开销相对于连结数成n^2增长,但是epoll的复杂度还是n。

    
 
 

您可能感兴趣的文章:

  • pc和开发板上使用select多路复用,不同的现象问题请教。
  • linux 下多线程 每个线程能否使用alarm来处理,信号是否会乱呢?
  • 困惑:子线程如何使用主线程的变量?
  • 如何实现这样的API,可同时被不同的进程/线程使用,但是又不区分进程/线程?
  • 请问在单进程,多线程程序里,线程间使用IPC的信号量来同步,能行吗?
  • java多线程编程之使用runnable接口创建线程
  • java线程之使用Runnable接口创建线程的方法
  • 使用信号量如何退出线程?
  • 多线程中动态链接库的使用
  • Java多线程之中断线程(Interrupt)的使用详解
  • 在多线程中使用select
  • 在unix下做webserver,使用多进程?多线程?
  • 如何锁定源代码,一次只能有一个线程使用?
  • 各位大侠,想问问驱动程序中(linux或者windows平台)可否使用线程?
  • 请教:多线程使用同一个socket进行数据收发会出现什么问题?
  • 请问如果要同时使用STL和多线程,会很麻烦么
  • 驱动多线程中频繁使用mdelay会对系统造成问题吗?
  • 有没有使用过Linux下线程池技术的高手,请为我指点迷津!!!
  • 请教一个pthread线程库的使用的问题
  • Shell有没有多线程,怎么使用?!
  • 请问可以在一个Servlet里使用多线程和SOCKET吗?
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • linux系统下使用使用性能监视工具的前提?
  • 性能测试中应该用top命令统计cpu使用情况还是ps命令?
  • 请教各位:只安装TOMCAT而不搭配apache一起使用,在性能上有什么差别
  • Mysql自带profiling性能分析工具使用分享
  • 强制SQL Server执行计划使用并行提升在复杂查询语句下的性能
  • 操作系统 iis7站长之家
  • 使用sqlbulkcopy提高导入数据的性能的方法
  • 【求助贴】数据库基准性能测试OSDL以及其工具的BDT系列的使用
  • mysql性能优化脚本mysqltuner.pl使用介绍
  • MySQL性能分析及explain的使用说明
  • 在Python中使用异步Socket编程性能测试
  • 在Nginx中使用X-Sendfile头提升PHP文件下载的性能(针对大文件下载)
  • 如何书写高质量jQuery代码(使用jquery性能问题)
  • MySQL索引背后的之使用策略及优化(高性能索引策略)
  • JAVA LinkedList和ArrayList的使用及性能分析
  • C++ I/O 成员 tellg():使用输入流读取流指针
  • 在测试memset函数的执行效率时,分为使用Cash和不使用Cash辆种方式,该如何控制是否使用缓存?
  • C++ I/O 成员 tellp():使用输出流读取流指针
  • 求ibm6000的中文使用手册 !从来没用过服务器,现在急需使用它,不知如何使用! 急!!!!!
  • Python不使用print而直接输出二进制字符串
  • 请问:在使用oracle数据库作开发时,是使用pro*c作开发好些,还是使用库函数如oci等好一些啊?或者它们有什么区别或者优缺点啊?
  • Office 2010 Module模式下使用VBA Addressof
  • 急求结果!!假设一个有两个元素的信号量集S,表示了一个磁带驱动器系统,其中进程1使用磁带机A,进程2同时使用磁带机A和B,进程3使用磁带机B。
  • windows下tinyxml.dll下载安装使用(c++解析XML库)
  • c#中SAPI使用总结——SpVoice的使用方法
  • tcmalloc内存泄露优化c++开源库下载,安装及使用介绍
  • 使用了QWidget的程序,如何使用后台程序启动它?
  • sharepoint 2010 使用STSNavigate函数实现文件下载举例
  • 共享内存一般是怎么使用的,是同消息队列配合使用么
  • 使用libpcap读取tcpdump抓取的文件并解析c代码实例
  • Jsp可否使用带有GUI的JavaBean,如何使用?


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3