Как предотвратить утечку памяти в приложении Mono MVC3?
Mono MVC 3 Корзина покупок Веб-приложения работают под Apache в Mono. В верхнем выводе ниже есть 3 приложения с пидами 31398, 30851, 30854. Процессы отсортированы по%MEM.
Через некоторое время появляется много моно процессов, которые занимают всю память, и Linux OOM начинает их убивать. После этого процессы запускаются снова и использование памяти продолжает увеличиваться.
Как это исправить или диагностировать так, чтобы моно не съел всю память? Использование Mono 2.10 с.NET 4
Похоже, что эта проблема вызвана простым просмотром веб-страниц или доступом к ботам Google.
top - 16:12:25 up 26 days, 4:34, 1 user, load average: 0.23, 0.17, 0.11
Tasks: 65 total, 1 running, 64 sleeping, 0 stopped, 0 zombie
Cpu(s): 0.3%us, 0.3%sy, 0.0%ni, 98.6%id, 0.7%wa, 0.0%hi, 0.0%si, 0.0%st
Mem: 1048576k total, 1023596k used, 24980k free, 0k buffers
Swap: 0k total, 0k used, 0k free, 582340k cached
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
31398 www-data 20 0 254m 122m 5692 S 0.3 11.9 0:29.38 mono
30851 www-data 20 0 202m 71m 4552 S 0.0 6.9 0:13.70 mono
30854 www-data 20 0 245m 51m 4196 S 0.0 5.0 0:05.74 mono
31413 postgres 20 0 117m 47m 29m S 0.0 4.6 0:16.04 postgres
32235 postgres 20 0 111m 40m 27m S 0.0 3.9 0:00.59 postgres
31803 postgres 20 0 106m 35m 28m S 0.0 3.5 0:01.96 postgres
30342 postgres 20 0 99888 26m 25m D 0.3 2.6 0:02.49 postgres
882 postgres 20 0 103m 23m 19m S 0.0 2.3 0:00.13 postgres
973 postgres 20 0 102m 17m 13m S 0.0 1.7 0:00.07 postgres
942 postgres 20 0 102m 16m 12m S 0.0 1.6 0:00.15 postgres
30867 www-data 20 0 58172 14m 2604 S 0.0 1.4 0:00.71 mono
30849 www-data 20 0 51212 12m 2604 S 0.0 1.2 0:00.66 mono
32234 postgres 20 0 99.4m 11m 9388 S 0.0 1.2 0:00.02 postgres
30847 www-data 20 0 50000 11m 2560 S 0.0 1.2 0:00.63 mono
30863 www-data 20 0 50000 11m 2560 S 0.0 1.1 0:00.64 mono
32568 postgres 20 0 99.6m 10m 8304 S 0.0 1.1 0:00.05 postgres
30439 postgres 20 0 99.3m 10m 8120 S 0.0 1.1 0:00.03 postgres
616 postgres 20 0 99.5m 10m 7324 S 0.0 1.0 0:00.06 postgres
971 postgres 20 0 99.4m 9.8m 7196 S 0.0 1.0 0:00.01 postgres
954 postgres 20 0 101m 9288 6544 S 0.0 0.9 0:00.00 postgres
32225 postgres 20 0 98.7m 8812 6344 S 0.0 0.8 0:00.02 postgres
31410 postgres 20 0 98.7m 8708 6272 S 0.0 0.8 0:00.06 postgres
946 postgres 20 0 99.2m 8648 5928 S 0.0 0.8 0:00.01 postgres
785 postgres 20 0 99.3m 7912 5152 S 0.0 0.8 0:00.00 postgres
972 postgres 20 0 99.2m 7808 5136 S 0.0 0.7 0:00.00 postgres
32297 postgres 20 0 99.2m 7688 5016 S 0.0 0.7 0:00.02 postgres
1 ответ
В MonoFastCGI есть небольшая ошибка утечки памяти, которая может также оказать влияние на интеграцию Apache ModMono (так как они оба используют некоторый код).
При использовании FastCgi есть обходной путь: используйте доменные сокеты Unix вместо локальных портов. Таким образом, вы можете попробовать перейти на использование этой технологии (которая реализуется многими веб-серверами, не только Apache). В моем случае я использовал его с nginx, и я был очень доволен. Больше информации здесь.
Кроме того, на вашем месте я бы также обновился до Mono 3.x.