Я хочу знать: моя система может работать 50000 нет. параллельных потоков/процесса или нет?Сколько потоков/процессов можно запустить на моей 64-битной машине
Для этого я изменил свой 'ulimit max process' и '/ proc/sys/kernel/pid_max' на 50000. Но все же я не могу пересечь ~ 33000 нет. процесса/потоков.
Отметить нет. процесса/потоков в моей системе я использую: ps -eL | wc -l И я написал программу java для создания тех, нет. потоков.
но в прошлом я получаю это исключение:
Java HotSpot(TM) 64-Bit Server VM warning: Attempt to protect stack guard pages failed.
Java HotSpot(TM) 64-Bit Server VM warning: Attempt to protect stack guard pages failed.
Java HotSpot(TM) 64-Bit Server VM warning: Attempt to protect stack guard pages failed.
Java HotSpot(TM) 64-Bit Server VM warning: Attempt to deallocate stack guard pages failed.
Total thread created #**32515**
Exception in thread "main" java.lang.OutOfMemoryError: unable to create new native thread
at java.lang.Thread.start0(Native Method)
at java.lang.Thread.start(Thread.java:640)
at HowManyThreads.main(HowManyThreads.java:12)
Java HotSpot(TM) 64-Bit Server VM warning: Attempt to deallocate stack guard pages failed.
Java HotSpot(TM) 64-Bit Server VM warning: Attempt to allocate stack guard pages failed.
^CJava HotSpot(TM) 64-Bit Server VM warning: Exception java.lang.OutOfMemoryError occurred dispatching signal SIGINT to handler- the VM may need to be forcibly terminated
Пожалуйста, помогите мне создать 50000 нет. процесса/потока.
ULIMIT -a
core file size (blocks, -c) 0
data seg size (kbytes, -d) unlimited
scheduling priority (-e) 0
file size (blocks, -f) unlimited
pending signals (-i) 2066250
max locked memory (kbytes, -l) 64
max memory size (kbytes, -m) unlimited
open files (-n) 150000
pipe size (512 bytes, -p) 8
POSIX message queues (bytes, -q) 819200
real-time priority (-r) 0
stack size (kbytes, -s) 10240
cpu time (seconds, -t) unlimited
max user processes (-u) 40000
virtual memory (kbytes, -v) unlimited
file locks (-x) unlimited
кот/Труды/SYS/ядро / pid_max
программа50000
Java
package create.threads;
public class HowManyThreads
{
private static Object s = new Object();
private static int count = 0;
public static void main(String[] argv)
{
try
{
for(;;)
{
new Thread(new Runnable()
{
public void run()
{
synchronized(s)
{
count += 1;
}
for(;;)
{
try
{
Thread.sleep(1000);
} catch (Exception e){
System.out.println(e);
}
}
}
}).start();
}
}
finally
{
System.out.println("Total thread created #"+count);
}
}
}
Это вывод бесплатно команда на моей системе: когда моя программа запускается и генерирует ошибку/исключение
free -g
total used free shared buffers cached
Mem: 252 3 248 0 0 0
-/+ buffers/cache: 3 249
Swap: 1 0 1
, когда я не запускать эту программу
free -g
total used free shared buffers cached
Mem: 252 2 250 0 0 0
-/+ buffers/cache: 1 250
Swap: 1 0 1
Не могли бы вы помочь мне ... где я что-то ....
'Исключение java.lang.OutOfMemoryError' должен дать вам ключ ... – isedev
пожалуйста, проверьте свободный вывод команды. У меня 252 ГБ памяти :). И моя программа, использующая только 2 ГБ памяти. – Upendra