bad file descriptor的解决办法

阅读: 评论:0

bad file descriptor的解决办法

bad file descriptor的解决办法

socket创建套接字之后,返回的市一个整型 值,对应的是进程描述字的索引号。

文件描述符数量是有限的,不停的创建套接字,当然会消耗完,导致open失败。

就是你open时产生的句柄之类的DD(对于你的情况就是 fd=socket()),然后不释放或关闭时,当达到操作系统支持的最大值时,就无法再打开了。在Solaris上可以ulimit修改最大值。

 

服务器使用select()模型,把可读的套接字及可写的套接字分别放入共享内存的读套接字队列及写套接字队列。由两个子进程从共享内存中读出可读和可写套接字分别处理读套接字和写套接字。

问题:客户端连上服务器后向服务器发送数据,服务器主进程把可读的套接字放入共享内存的读套接字队列中,然后子进程从共享内存中读出套接字,然后用该套接字调用recv()读数据。程序返回错误,错误码提示是bad file descriptor。请问是什么原因呢?

另外想问FD_ISSET(),

select(maxFd + 1, &readSet, &writeSet, NULL, NULL);

某个连接上来的套接字connectfd,客户端并没有发送任何数据,为什么用FD_ISSET(connectfd, &readSet)判断总是返回该套接字可读呢?

在子进程创建之后,父进程又打开的新的套接字子进程应该无法再直接使用了。

父进程里的连接,检测到数据后,子进程去recv?
这样应该不行吧?每个进程都有缓冲区数据,select检测到的数据又不在子进程的缓冲区,不能用子进程去读吧。你可以在父进程里读出来后,写入共享内存,给子进程。

 

本文发布于:2024-01-29 05:00:42,感谢您对本站的认可!

本文链接:https://www.4u4v.net/it/170647564912871.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:解决办法   bad   file   descriptor
留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23