我的linux tcp server最多只能同时进行10个TCP请求,其余的都在等待了,如何让所有的连接都同时进行?

犇犇犇程序猿 2008-12-03 05:00:16
一个问题, 我的linux Server 最多只同时接收10个tcp请求, 其余的都在等待了。请问是什么原因如何修改。

每次到来一个请求,我都新建一个子进程处理流程。

if((sockfd=socket(AF_INET,SOCK_STREAM,ZERO))==-1)		//建立一个套接字描述符。 
{
exit(1);
}
/* 服务器端填充 sockaddr_in结构 */

bzero(&server_addr,sizeof(struct sockaddr_in));

server_addr.sin_family=AF_INET;

server_addr.sin_addr.s_addr=htonl(INADDR_ANY); /*IP地址转换为网络字节序*/

server_addr.sin_port=htons(portnumber); /*端口号转换为网络字节序*/

/* 捆绑sockfd描述符 */

if(bind(sockfd,(struct sockaddr *)(&server_addr),sizeof(struct sockaddr))==-1)
{
printf("Bind error:%s\n\a",strerror(errno));
exit(1);
}

/* 监听sockfd描述符 */

if(listen(sockfd,500)==-1) /*5为请求队列的最大请求数*/
{
printf("Listen error:%s\n\a",5(errno));
exit(1);
}

printf("socket is %d\n", sockfd); //打印套接字句柄。
signal( SIGCHLD , sig_chld ); //杀死子进程中的僵尸进程。

/*
if(fork() == 0) //新建一个子进程,用于操作串口,读取通信模块所收到的短信。
{
//tGuard(); //串口监控进程,不会返回,一直监控。若有CQT模块报警,那么就通过其中的函数完成相应的工作。
exit(0);
}
*/

for( ; ; ) // 服务器不断的监听。
{ //阻塞 ,直到一个连接连接过来。

new_fd = accept(sockfd , (struct sockaddr *)(&client_addr),&sin_size);

if((pid=fork())==ZERO)



很费解的是最多10个连接,请问是内核设定的么?
...全文
440 15 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
15 条回复
切换为时间正序
请发表友善的回复…
发表回复
threeleafzerg007 2008-12-04
  • 打赏
  • 举报
回复
这是不是 你对每个进程所能拥有的最大数目子进程进行了设置

要不就听楼上的改成 select吧 资源还能省下不少
benbenxiaoluchi 2008-12-04
  • 打赏
  • 举报
回复
俺建议改成IO多路复用select方式实现。
benbenxiaoluchi 2008-12-04
  • 打赏
  • 举报
回复
自己在虚拟机上测试吧,呵呵。正好可以定位下到底是环境/权限/资源问题还是代码问题。
backlog 最大128, 楼主设500,也没有问题

如果怀疑是另一个SERVER, 而且另一个SERVER采用并发技术 而不是多路复用的话,
是否可以 ps -ef|grep 进程名 看看他到底起了多少个进程。(俺不知道咋看并发连接数,只能这么看了)






犇犇犇程序猿 2008-12-04
  • 打赏
  • 举报
回复
不敢随便改, 怕改瘫服务器 我就不好说了。。
犇犇犇程序猿 2008-12-04
  • 打赏
  • 举报
回复
我查看了 /proc/sys/net/core/netdev_max_backlog 值为128
我这台服务器 还跑另外一个服务程序,可能是这个原因。。
犇犇犇程序猿 2008-12-04
  • 打赏
  • 举报
回复
if((pid=fork())==ZERO)
以下的 都是业务逻辑的 代码了, 每个独立的进程做独立的事情,应该是没有影响的。

我的情况是, 每当一个新的连接到来时, 若没超过10个进程, 接受并且进行通信,超过10个进程时, 就直接等待了(backlog)。 我把最先请求的 客户端关掉时, 在backlog中等待的客户端就可以连接上了。 囧啊···
hankwangwang 2008-12-04
  • 打赏
  • 举报
回复
用strace跟一下你的主进程在挂载10个连接的时候,在干什么;

另外,也可以考虑一下排出法,在一台干净的机器上运行你这个程序;避免是其他程序的影响
hankwangwang 2008-12-04
  • 打赏
  • 举报
回复
select和epoll都可以处理并发连接的问题

楼主的问题也是别的原因产生的,可以尝试着多打印日志,strace跟踪,gdb调试等方式查找一下;
出现问题时,找到问题的根源了,才是进步的方法;
ma100 2008-12-04
  • 打赏
  • 举报
回复
你把进程换成线程试试,也许是资源消耗太多了
犇犇犇程序猿 2008-12-04
  • 打赏
  • 举报
回复
业务逻辑哪里 就是用select 实现的。 超过10个TCP请求时,accept 这里就被阻塞了。
hankwangwang 2008-12-03
  • 打赏
  • 举报
回复
楼主现在贴出来的这部分代码不会影响到楼主说的那个问题

if(listen(sockfd,500)==-1)
操作系统默认的128,大于128的,默认用128;
这里的意思也不是最大请求数;这里设置的值的作用是,同一个时刻,同时挂载上来的用户请求,操作系统只接受128个,再多的,就会超时3秒
一般是具有非常大的并发请求才需要调高这个值,像楼主的这个问题,你这里写个5,都能满足你的要求


应该是别的地方的问题,需要别人帮忙的话,请把详细的代码贴一下
bshawk 2008-12-03
  • 打赏
  • 举报
回复
另外,也关注下: /proc/sys/net/core/netdev_max_backlog !

good luck!
bshawk 2008-12-03
  • 打赏
  • 举报
回复
尝试修改/proc/sys/net/core/somaxconn的值看看!

try:
echo 1024 > /proc/sys/net/core/somaxconn !


good luck!

  • 打赏
  • 举报
回复
汗,不好意思,看错了。500不是端口。。是最大连接数。
  • 打赏
  • 举报
回复
可不可以不要用500这个端口?换成5000以上,比如5555试下。貌似1到1000是保留端口呢。

23,217

社区成员

发帖
与我相关
我的任务
社区描述
Linux/Unix社区 应用程序开发区
社区管理员
  • 应用程序开发区社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧