gpt4 book ai didi

c - epoll - 轮询多个文件描述符(即套接字)

转载 作者:塔克拉玛干 更新时间:2023-11-03 01:35:54 24 4
gpt4 key购买 nike

我阅读了手册页并浏览了这个示例的用法:https://banu.com/blog/2/how-to-use-epoll-a-complete-example-in-c/ ,但我想不出一种方法来使用 epoll 做我想做的事情,有人能帮我一些忙吗?

基本上我正在编写一个 netcat 类型的实用程序来更好地学习 C/网络。我已经创建了一个可以在一个端口上监听和连接的基本服务器/客户端。现在我想扩展服务器方面来监听端口范围。

我计划通过为每个端口创建 socket()、bind() 和 listen() 的 for 循环来执行此操作。

由于端口范围可达 65k,我需要轮询它们并在收到连接请求时接受()。

Unlinke 典型的 C 服务器使用轮询或 epoll 处理一个端口上的多个连接,这是数千个潜在端口之一上的一个连接。我无法从示例中完全了解如何对套接字进行 epoll 以及在请求连接时接受它并取消绑定(bind)/停止监听/轮询。

有人有任何示例解释/代码可以让我开始吗?

最佳答案

1 - 创建所有服务器套接字

2 - 它们的文件描述符将包含在一个范围内,例如 [4, 199]

3 - 在循环中将它们全部添加到 epoll 描述符中。

然后在正常的 epoll 循环中,如果带有事件的描述符在 [4,199] 范围内或实际范围内的任何范围,那么您知道它是一个服务器套接字并且您需要接受它,否则做任何事情你用你的连接描述符来做。

另一种方法是创建 2 个 epoll 描述符,一个只用于服务器套接字,另一个只用于连接的描述符。这样做的好处是你需要对它们都使用 epoll !所以我不建议这样做。

由于您要创建的描述符数量如此之大,您很可能需要更改一些内核参数,因为在一个进程中打开如此多的描述符可能会达到某个限制。

关于c - epoll - 轮询多个文件描述符(即套接字),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19044304/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com