加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

java – 如何增加最大数量的JVM线程(Linux 64bit)

发布时间:2020-12-14 05:34:41 所属栏目:Java 来源:网络整理
导读:我不能在 Linux机器上创建超过32k的Java线程,内存为15G. 解决方法 您可以使用 sample program来查找当前线程限制. 如果在线程“main”中遇到异常java.lang.OutOfMemoryError:无法创建新的本机线程,请检查这些: 在小型内存机器中 每个Java线程都使用自己的
我不能在 Linux机器上创建超过32k的Java线程,内存为15G.

解决方法

您可以使用 sample program来查找当前线程限制.

如果在线程“main”中遇到异常java.lang.OutOfMemoryError:无法创建新的本机线程,请检查这些:

>在小型内存机器中

每个Java线程都使用自己的堆栈内存.默认堆栈大小为1024k(= 1M).您可以减少堆栈大小,如java -Xss512k ….如果堆栈大小太小,则无法启动JVM.

并注意堆内存配置:(初始)-Xms和(最大)-Xmx.分配给堆的内存越多,堆栈的可用内存越少.
>系统限制

ulimit -a中的某些值可能会影响线程限制.

>最大内存大小 – 在大多数64位计算机上无限制
>最大用户进程 – linux处理线程像进程
>虚拟内存 – 在大多数64位计算机上无限制.虚拟内存使用量增加了-Xss配置(默认1024k)

您可以通过(临时)运行ulimit命令或(永久)编辑/etc/security/limits.conf来更改这些值.
> sys.kernel.threads-max

该值是系统全局(包括非JVM进程)最大线程数.检查cat / proc / sys / kernel / threads-max,并在必要时增加.

回波999999>的/ proc / SYS /内核/线程-MAX
要么
/etc/sysctl.conf中的sys.kernel.threads-max = 999999永久性更改.
> sys.kernel.pid_max

如果cat / proc / sys / kernel / pid_max与当前限制相似,请增加此值. Linux会像进程一样处理线程.

回波999999>的/ proc / SYS /内核/ PID_MAX
要么
/etc/sysctl.conf中的sys.kernel.pid_max = 999999永久性更改.

您也可能需要增加sys.vm.max_map_count.
> sys.vm.max_map_count

cat / proc / sys / vm / max_map_count应至少为(2个线程计数).

尝试保护堆栈保护页失败.和OpenJDK 64位服务器VM警告:尝试取消分配堆栈保护页面失败.错误消息由JavaThread :: create_stack_guard_pages()发出,它调用os :: guard_memory().在Linux中,这个函数是mprotect().

echo 1999999>的/ proc / sys目录/ VM / max_map_count要么sys.vm.max_map_count = 1999999在/etc/sysctl.conf中永久更改.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读