大发PK10APP下载_大发PK10APP官网 - 大发PK10APP下载,大发PK10APP官网是新浪网最重要的频道之一,24小时滚动报道国内、国际及社会新闻。每日编发新闻数以万计。

操作系统能否支持百万连接?

  • 时间:
  • 浏览:0

说明当前 Linux 系统的每有有1个多多应用程序都可以不需要 最多打开 1024 个文件. 为了支持 C10000K, 你同样时要修改你什儿 限制.

编辑 /etc/security/limits.conf 文件, 加入如下行:

int bufsize;

/proc/sys/net/ipv4/tcp_wmem

第有有1个多多数字 101747 假使 当前系统的全局最大打开文件数(Max Open Files), 都可以看后, 都可以不需要 10 万, 所以, 在这台服务器上无法支持 C10000K. 所以系统的你什儿 数值更小, 为了修改你什儿 数值, 用 root 权限修改 /etc/sysctl.conf 文件:

const char *ip = argv[1];

socklen_t optlen;

服务器

int main(int argc, char **argv){

总结

int ret = select(maxfd + 1, &readset, NULL, NULL, NULL);

int index = 0;

printf("select error! %sn", strerror(errno));

struct sockaddr_in addr;

for(int i=0; i

setsockopt(serv_sock, SOL_SOCKET, SO_SNDBUF, &bufsize, sizeof(bufsize));

bufsize = 100000;

}

int sock;

fs.file-max = 10100000

永久修改

Linux 系统时要修改内核参数和系统配置, 不需要 支持 C10000K. C10000K 的应用要求服务器至少时要 2GB 内存, 可能性应用你什儿 还时要内存, 你什儿 要求应该是至少 10GB 内存. 一起去, 网卡应该至少是万兆网卡.

51000 0 101747

exit(0);

if(argc <= 2){

注意: Linux 内核源码中饱含1个多多多常量(NR_OPEN in /usr/include/linux/fs.h), 限制了最大打开文件数, 如 RHEL 5 是 1048576(2^20), 所以, 要想支持 C10000K, 你可能性还时要重新编译内核.

客户端

来控制 TCP 连接的发送和接收缓冲的大小(多谢 @egmkang).

不过, 可能性你都不 root, 可能性都可以 修改超过 1024, 会报错:

}

net.ipv4.netfilter.ip_conntrack_max = 10100000

base_port = atoi(argv[1]);

}else{

第一列的 work 表示 work 用户, 让人填 *, 可能性 root. 或者保存退出, 重新登录服务器.

/*

int port = base_port + index;

printf("connect to %s:%dn", ip, port);

int bufsize;

if(ret > 0){

1024

addr.sin_family = AF_INET;

printf("Usage: %s ip portn", argv[0]);

char tmp_data[10];

if(ret < 0){

注意, 服务器监听了 10 个端口, 这是为了测试方便. 可能性都可以不需要 一台客户端测试机, 最多都可以不需要 跟同有有1个多多 IP 端口创建 100000 多个连接, 所以服务器监听了 10 个端口, 原先一台测试机就都可以和服务器之间创建 1000 万个连接了.

}

通过上边的测试代码, 都可以发现, 应用应用程序维持百万个空闲的连接, 只会占用操作系统的内存, 通过 ps 命令查看可知, 应用应用程序你什儿 几乎不占用内存.

if((sock = socket(AF_INET, SOCK_STREAM, 0)) == -1){

在 Linux 下执行:

if(++index >= 10){

会打印出这类下面的一行输出:

}

index = 0;

int opt = 1;

}

ulimit -n

全局限制

setsockopt(serv_sock, SOL_SOCKET, SO_RCVBUF, &bufsize, sizeof(bufsize));

inet_pton(AF_INET, ip, &addr.sin_addr);

if(connect(sock, (struct sockaddr *)&addr, sizeof(addr)) == -1){

-bash: ulimit: open files: cannot modify limit: Operation not permitted

int base_port = 7000;

应用程序限制

}

while(1){

return 0;

}

continue;

bzero(&addr, sizeof(addr));

参考:

*/

}

const char *ip = "0.0.0.0";

net.ipv4.ip_conntrack_max = 10100000

对于绝大每种 Linux 操作系统, 默认具体情况下虽然不支持 C10000K! 可能性操作系统饱含最大打开文件数(Max Open Files)限制, 分为系统全局的, 和应用程序级的限制.

addr.sin_port = htons((short)port);

下面来分别对这几块哪些的间题进行分析.

正确处理了操作系统的参数限制, 接下来就要看看内存的占用具体情况. 首先, 是操作系统你什儿 维护哪些连接的内存占用. 对于 Linux 操作系统, socket(fd) 是有有1个多多整数, 所以, 猜想操作系统管理一百万个连接所占用的内存应该是 4M/8M, 再包括什儿 管理信息, 应该会是 1000M 左右. 不过, 还有 socket 发送和接收缓冲区所占用的内存没法 分析. 为此, 我写了最原始的 C 网络应用程序来验证:

struct sockaddr_in addr;

socklen_t optlen;

int server_socks[MAX_PORTS];

maxfd = server_socks[i];

都可以修改

work hard nofile 10100000

/proc/sys/net/ipv4/tcp_rmem

for(int i=0; i maxfd){

sock_err:

}

printf("press Enter to continue: ");

goto sock_err;

}

exit(0);

goto sock_err;

int connections = 0;

if(argc > 2){

connections ++;

当然, 这仅仅是理论分析, 实际的应用时要更多的内存和 CPU 资源来正确处理业务数据.

return 0;

}

int opt = 1;

printf("error: %sn", strerror(errno));

cat /proc/sys/fs/file-nr

}

if(connections % 100000 == 9999){

执行:

int connections = 0;

ulimit -n 10100000

临时修改

getchar();

usleep(1 * 10000);

if(errno == EINTR){

work soft nofile 10100000

假设百万连接饱含 20% 是活跃的, 每个连接每秒传输 1KB 的数据, 没法 时要的网络数率是 0.2M x 1KB/s x 8 = 1.6Gbps, 要求服务器至少是万兆网卡(10Gbps).

我测试 10 万个连接, 哪些连接是空闲的, 哪些数据假使 发送假使 接收. 这时, 应用程序只占用了都可以 1MB 的内存. 或者, 通过应用程序退出前后的 free 命令对比, 发现操作系统用了 1000M(大致)内存来维护这 10 万个连接! 可能性是百万连接一句话, 操作系统你什儿 就要占用 2GB 的内存! 也即 2KB 每连接.

int base_port = atoi(argv[2]);

输出:

int main(int argc, char **argv){

printf("connections: %d, fd: %dn", connections, sock);