33--一个进程最多可以创建多少个线程?

这个问题是基于Linux系统下的测试,它跟两个因素有关:进程的虚拟内存上限和系统参数限制。

  1. 进程的虚拟内存上限:

创建线程需要分配栈空间,创建的越多,需要分配的栈空间越多,占用的虚拟内存就越多。

  1. 系统参数限制:

会有系统级别的参数来控制整个系统的最大线程个数。

输入 ulimit -a 后:

如上图我们可以知道服务器默认分配给线程的栈空间大小为8M(倒数第五行)。

通过top -H 可以查看当前系统的线程数,如下图:

可以看到线程数为37405(第二行)。

再执行下列代码:

cs 复制代码
#include <stdio.h>
#include <unistd.h>
#include <pthread.h>
#include <stdlib.h>

void *thread(void *arg)
{
    printf("hello\n");
}

int main()
{
    int res=0;
    int count=0;
    pthread_t id;
    while(res==0)
    {
        res=pthread_create(&id,NULL,thread,NULL);
        count++;
        printf("count=%d\n",count);
    }
    exit(0);
}

得到结果如下:

由上图可以看到创建了32755个线程,也就是说,不能再创建了。

因为其受上述两个因素的影响,故将栈空间大小该变一下,

默认情况下,线程栈的大小通常为8MB。在内存允许的前提下,可以通过减小线程栈的大小,来增加可以创建的线程数量。较小的栈将允许更多的线程同时存在。

如果减少到4MB(4096KB),每个线程的栈空间将占用更少的内存,这样可以创建更多线程。但要注意,栈空间过小可能导致某些操作(尤其是递归操作或需要较大栈空间的操作)出错。

将栈大小改为4MB,输入如下命令:

ulimit -s 4096

再次测试,得到还是32755。

然后将线程数设置为100000,在管理员的身份下,输入如下命令:

echo 100000 | sudo tee /proc/sys/kernel/threads-max

同上还是32755。造成这种情况的原因是因为它不只是跟上述两个因素有关,还会受到资源限制、系统配置、系统内存使用情况以及用户级进程数限制等等的影响。故可以继续检查会受到影响的因素,修改调整,可能会有所改变,并进一步分析。(这里就不进一步分析了)

相关推荐
m0_74004373几秒前
Spring和SpringBoot和SpringMVC 的关系总结
java·spring boot·spring·mvc
weixin_307779133 分钟前
Jenkins Matrix Authorization Strategy插件:详解与应用指南
运维·开发语言·架构·jenkins
float_com5 分钟前
【JavaWeb常见BUG】—— Lombok依赖失效问题
java·javaweb·bug分析与解决
赖small强6 分钟前
【Linux 内存管理】深入解析 Linux Cache Line 的原理、价值及 MIPS CPU 处理机制
linux·缓存·内存对齐·cache line
通往曙光的路上6 分钟前
异步任务la
java·开发语言
星释6 分钟前
Rust 练习册 116:杂志剪贴侦探游戏
开发语言·后端·rust
CaracalTiger7 分钟前
在openEuler操作系统中多样性算力支持与性能压力测试操作
linux·运维·git·开源·开放原子·压力测试·开源软件
风123456789~8 分钟前
【Linux专栏】rsync实验-同步指定日期前的文件
linux·脚本·rsync
SadSunset11 分钟前
(16)MyBatis执行流程分析(偏上层架构)
java·架构·mybatis
Tan_Ying_Y11 分钟前
JVM内存结构,什么是栈桢?
java·jvm