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

关于在LINUX下开发有上千个Client连接的Server的技术. 请大家讨论和指点

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

    本文导语:  在Windows NT下做高性能服务器时, 我们会采用完成端口的技术.  在Linux下做开发时,为了效率一般是用多路I/O复用(如select()), 在性能要求不高的情况, 这种技术是可以满足的.  但当Client达到一定的数量时(如1000 个), ...

在Windows NT下做高性能服务器时, 我们会采用完成端口的技术.  在Linux下做开发时,为了效率一般是用多路I/O复用(如select()), 在性能要求不高的情况, 这种技术是可以满足的.  但当Client达到一定的数量时(如1000 个), 这时候应该采用什么技术呢?

|
哪里的测试?玩linux要是勇敢的话就/dev/epoll。
如果是我,宁可freebsd的kqueue

|
posix标准中应该有异步IO的函数---AIO_***函数组

所以异步IO是这种程序最好选择---ACE有实现


不过我没有用过epoll,听说2.6内核很强劲阿  呵呵

|
我来讲讲我的想法,我采用select+forK()来解决。
主进程接受100个CLIENT连接时,就FORK一个子进程,父进程关闭此100个CLIENT连接。由子进程接管这100个CLIENT,子进程采用SELECT方法进行管理,当CLIENT都退出时,子进程退出。
父进程ACCEPT和处理CLIENT连接,也要处理CLIENT数据。

|
select好像只能管理1024的socket,多了不行。
poll好像是可以的。
另,多线程在client多的时候,也不是很好管理的,可以想像,你创建10000个线程(如果你的系统允许的话)会怎么样。

|
用线程实现是最好的,,, 控制方便, 实现相对相言简单,,

据有关测试, 当CLIENT数量相当大时,用线程实现比SELECT实现效果要好。

|
多线程+多路I/O复用
还可以使用异步处理方式,接收数据与数据加工处理由不同的线程完成。

|
用线程的话,不知道行不行,因为在linux下,我用线程编程的时候发现线程退出后,即使你使用了pthread_join或者是设定线程为depatch,一样会在内核留下一个状态为zombie的进程句柄,虽然不占内存,不知道多了有没有影响。
这里还有linux之父Linus Torvalds与他人关于此事的讨论。
http://kerneltrap.org/node/view/1795

|
系统好像不能无休止的创建线程的她又一个最大限制

|
用线程池吧应该,有现成的线程池库,不过我不清楚到底是
哪个,有知道的吗???

|
http://www.kegel.com/c10k.html#top

这个基本上完全回答了这个帖子的问题

BTW 过年好像没什么人还在看程序的啊:)

|
我曾开发过DICOM影像服务器,用的是select+fork没觉得怎么耗资源啊。

|
用线程池,我觉得是最好的解决方案。

|
多线程 + I/O复用

|
这个我要顶一下,希望看到更多精彩回答。:)

    
 
 

您可能感兴趣的文章:

  • 关于Linux中romfs的问题,请高手指点指点
  • 菜鸟求救:在linux下安装jdk失败。初次使用linux,还请各路大虾指点指点,不甚感激!!!
  • 我的linux的安装问题,请大家给指点指点。多谢了!!!
  • 求高手指点,arm-linux
  • Linux 安装开发环境报错 求指点
  • 请各位使用过Linux的进来看看,指点指点(在线等待)! 谢谢
  • Linux的嵌入式开发,请高手指点
  • 刚刚进入linux下编程,请指点入门~~~
  • linux内核里面的所有头文件,有没有整理过的,请高手指点!谢谢!!!
  • 如何运程控制 linux 请高手指点。
  • 何运程控制 linux 请高手指点。
  • 想走嵌入式linux设备驱动方向,请多指点
  • 请指点: 在windows下能否通过程序来获取linux下的用户列表,甚至通过自己写的windows程序界面增加修改linux的用户
  • 板载AC97声卡的驱动问题,望Linux 高手指点
  • linux平台下面,能同时支持php,asp吗,如果可以,能不能详细指点。 在线等候!
  • 请linux的gnome开发高手指点
  • 关于在VMware下安装linux,请高手指点,先谢过!
  • 下一步该学习linux/unix的什么?请高手指点……
  • 有关linux这方面的应用和发展方向有哪位高手可以指点我一下!!!
  • linux下如何执行project文件,高人指点。
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • 在XP下使用VMWare安装了Linux AS 5.6之后,使用FTP工具可以远程连接Linux,而在cmd命令行中却连接不上,什么原因 ?
  • linux 有线连接了却显示有线连接断开是怎么回事
  • 请问unix/linux下动态连接库和静态连接库有什么区别?
  • LINUX中连接C++的库怎么连接.库在什么位置,还有什么特殊命令吗?
  • 在linux下可以使用dao方式连接数据库吗?可以连接musql吗?回答就给分!急
  • 在线请教:linux下用MySQL C API 连接MySQL 4.1.12出现的连接问题,提示升级客户端!!!!!!
  • ftp连接问题,就是linux连接windows ftp的问题,高手请进(在线等待)!!!!!
  • Linux下的C++程序怎么连接WIN2000下的SQL Server 2000?或者如何连接MySQL?
  • linux 下连接创建连接数据库程序,什么都可以 。谁知道300分
  • [疑问] [linux网络连接]Linuxmint网络连接
  • LINUX C 进行TCP网络连接,怎样设置连接超时时间?
  • 我在telnet到linux上的时候报不能打开到主机的连接, 在端口23: 连接失败 请问是什么原因
  • linux vsftpd连接问题
  • Linux 下的C语言实现数据库连接池操作。
  • Linux 代理 一个客户端来就创建一个连接
  • SecureCRT连接linux。为什么我在linux的/etc/sysconfig/下找不到iptables?
  • linux问题 secureCRT连接的问题 在线等急!~~
  • 我想用Linux的串口和S3c2410x连接,请问在Linux里面怎么找到那个超级终端?
  • 高分求教,linux下的GPRS连接!!!
  • 用xmanager远程连接不上linux桌面
  • linux c/c++ IP字符串转换成可比较大小的数字
  • 在win分区上安装linux和独立分区安装linux有什么区别?可以同时安装吗?(两个linux系统)
  • linux哪个版本好?linux操作系统版本详细介绍及选择方案推荐
  • 在虚拟机上安装的linux上,能像真的linux系统一样开发linux程序么?
  • secureCRT下Linux终端汉字乱码解决方法
  • 我重装window后,把linux的引导区覆盖了,进不了linux怎么办?急啊,望热心的人帮助 (现在有linux的盘)
  • Linux c字符串中不可打印字符转换成16进制
  • 安装vmware软件,不用再安装linux系统,就可以模拟linux系统了,然后可以在其上学习一下LINUX下的基本操作 了?
  • Linux常用命令介绍:更改所属用户群组或档案属性
  • 红旗Linux主机可以通过127.0.0.1访问,但如何是连网的Win2000机器通过Linux的IP去访问Linux
  • linux命令大全详细分类介绍及常用linux命令文档手册下载


  • 站内导航:


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

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

    浙ICP备11055608号-3