您的位置:首页 > 编程语言 > Java开发

HBASE遇到的java.lang.OutOfMemoryError: unable to create new native thread解决方法

2016-04-15 15:39 821 查看
简单分享一下,类似问题的解决方法刚才在某机器上上xxx用户下压测时遇到这个问题,连xxx都进不去了说明xxx用户下无法创建跟多的线程了(当然root用户没这个问题) 系统能够创建的最大线程数:(MaxProcessMemory - JVMMemory – 系统内存) / (ThreadStackSize) = Number of threads有两种方式: 减少xxx下的ThreadStackSize 增加xxx下的nproc数量修改[lsmpusr@wxlab28bin]$ ulimit -acore filesize (blocks, -c) 0data segsize (kbytes, -d)unlimitedschedulingpriority (-e) 0filesize (blocks, -f) unlimitedpendingsignals (-i) 256636max lockedmemory (kbytes, -l) 64max memorysize (kbytes, -m) unlimitedopenfiles (-n) 65536pipesize (512bytes, -p) 8POSIX messagequeues (bytes, -q) 819200real-timepriority (-r) 0stacksize (kbytes, -s) 10240-----可以减小这个,建议在jvm –xss中减少cputime (seconds, -t) unlimitedmax userprocesses (-u) 1024-----可以增加这个到32000virtualmemory (kbytes, -v)unlimitedfilelocks (-x) unlimited修改/etc/security/limits.conf* soft nofile 65536
* hard nofile 65536
xxx soft nproc 32000
xxx hard nproc 32000
xxx soft stack 1024
xxx hard stack 1024
其中 xxx表示启动hbase的用户,如使用hadoop启动hbase,则配置如下:
* - nproc 102400
* - nofile 102400

hadoop hard nproc 32000
hadoop soft nproc 32000
hadoop hard stack 1024
hadoop soft stack 1024
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  HBASE