我正在编写一个需要处理许多打开的套接字的服务器,所以我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 版本)。