我正在编写一个需要处理多个打开的套接字(socket)的服务器,因此我使用setrlimit()
函数(在特权降低之前作为root用户)来设置最大文件描述符数。以下是示例代码:
#include <sys/resource.h>
#define MAX_FD_C 9001
if (setrlimit(
RLIMIT_NOFILE, &(struct rlimit){.rlim_cur = MAX_FD_C, .rlim_max = MAX_FD_C}
) == -1) {
perror("Failed to set the maximum number of open file descriptors");
return EXIT_FAILURE;
}
现在,我意识到可能不会有任何保证,并且我完全取决于Linux内核使用实现文件描述符表的方法;但是在实践中,假设此程序从Linux内核接收的任何fd值都小于我上面设置的MAX_FD_C,这是否合理?我希望尽可能紧凑地保留每个套接字数据,这可能意味着仅使用像
static struct client clients[MAX_FD_C] = {{0}};
这样的数组,并将fd用作客户端结构的索引(这基本上是我自己版本的FDT)。