• JVM截至多少线程可以创建: unable to create new native thread


    最近的测试需要很长的连接server。这些数据需要达到100W长连接,试client。一个线程来保持连接。查找linuxserver创建者默认3200当多个线程。这个错误将得到“java.lang.OutOfMemoryError: unable to create new native thread。并且,此时整个系统都不能创新新的线程了,不能连接终端,不能运行不论什么命令。

    貌似是内存不足。但实际内存尚有富余。经验证。是linux的一些内核參数限制了创建新的线程。




    由于要保持长连接。全部先改动client保证更大的分配port范围
    改动 /etc/sysctl.conf
    加入这样一行:
    net.ipv4.ip_local_port_range = 1024 61000


    改动系统參数

    echo "100000" > /proc/sys/kernel/threads-max
    echo "100000" > /proc/sys/kernel/pid_max     (默认32768)
    echo "200000" > /proc/sys/vm/max_map_count   (默认65530)


    改动/etc/security/limits.conf
    *       -      nproc      999999
    *       -      nofile      999999
    PS:nproc是改动系统的max user processes大小;nofile  是改动open files的大小。另外linux 2.6.25内核之前有个宏定义,定义了这个值的最大值,为1024*1024,正好是100万,而在2.6.25内核及其之后。这个值是能够通过/proc/sys/fs/nr_open来设置,只是,999999足够用了。

    非常多人可能会遇到。仅仅能启动32000多个线程就不能再起很多其它的线程了,事实上就是pid_max = 32768 给限制住了



    版权声明:本文博主原创文章,博客,未经同意不得转载。

  • 相关阅读:
    Android 浅谈相机研发
    Android线程和线程池
    android之多媒体篇(三)
    android之多媒体篇(二)
    android之多媒体篇(一)
    Android图片缩放方法
    android之BitmapFactory.Options的使用
    mac .bash_profile环境变量汇总
    免费的HTML5连载来了《HTML5网页开发实例具体解释》连载(六)媒体查询
    LeetCode
  • 原文地址:https://www.cnblogs.com/mengfanrong/p/4818711.html
Copyright © 2020-2023  润新知