Java程序在Linux上运行虚拟内存耗用很大

突然集群的2个节点挂了,通过top查看, 虚拟内存22G,

 

 通过 pmap -x 8 | grep anon

 

 

一大堆64M

Linux下glibc的内存管理机制用了一个很奇妙的东西,叫arena。在glibc分配内存的时候,大内存从从中央分配区分配,小内存则在线程创建时,从缓存区分配。为了解决分配内存的性能的问题,就引入了这个叫做arena的memory pool。而恰好,在64bit系统下面,它的缺省配置为64M。一个进程可以最多有cores*8个arena,假如服务器是4核的,那么最多有4*8=32个arena,也就是32*64 = 2048M内存。然而,为了满足业务,我这台服务器居然是12核的,单单一个进程的arena占用的内存就达到了6G。

可以发现,通过服务器上一个参数MALLOC_ARENA_MAX可以控制最大的arena数量

 

export MALLOC_ARENA_MAX=1

export PATH USER LOGNAME MAIL HOSTNAME HISTSIZE HISTCONTROL MALLOC_ARENA_MAX

 

重启后java进程, 查看效果。

 

 

参考: https://blog.csdn.net/u010686469/article/details/77319599

转载于:https://www.cnblogs.com/fengjian2016/p/9728318.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值