Модераторы: LSD, AntonSaburov
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> размер процесса 
V
    Опции темы
yuliada
Дата 18.4.2009, 03:59 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 82
Регистрация: 16.2.2009
Где: Иркутск - San Die go

Репутация: нет
Всего: нет



Есть некоторая программка, грузит в базу данные. В task manager видно, что память, занимаемая этим процессом постоянно растет, пока не съедается вообще все что можно. Но в VisualVM видно что Heap при этом остается адекватных размеров и не растет. Т.е. после того как прога достаточно долго работает размер Heap может быть например 800мб, а task manager показывает размер процесса 3Гб и продолжает расти. Почему это может быть и как с этим бороться?

Это сообщение отредактировал(а) yuliada - 18.4.2009, 04:06
PM MAIL   Вверх
yuliada
Дата 18.4.2009, 09:08 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 82
Регистрация: 16.2.2009
Где: Иркутск - San Die go

Репутация: нет
Всего: нет



Никакие потоки не создаются, т.е. количество потоков постоянное и тоже не растет.

Это сообщение отредактировал(а) yuliada - 18.4.2009, 09:34
PM MAIL   Вверх
powerOn
Дата 18.4.2009, 10:17 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


software saboteur
****


Профиль
Группа: Участник
Сообщений: 4367
Регистрация: 7.10.2005

Репутация: 47
Всего: 159



Программа в итоге падает с OutOfMemoryError?


--------------------
user posted image нет времени думать - нужно писать КОД!

PM MAIL   Вверх
yuliada
Дата 18.4.2009, 10:19 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 82
Регистрация: 16.2.2009
Где: Иркутск - San Die go

Репутация: нет
Всего: нет



Нет, не падает. Windows говорит что-то про low on memory и прибивает процесс, точно не помню, долго надо ждать чтобы всю память забить
PM MAIL   Вверх
powerOn
Дата 18.4.2009, 10:26 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


software saboteur
****


Профиль
Группа: Участник
Сообщений: 4367
Регистрация: 7.10.2005

Репутация: 47
Всего: 159



Программу вы сами писали? Версия JVM? Какое ограничение памяти установлено (опция -Xmx)?


--------------------
user posted image нет времени думать - нужно писать КОД!

PM MAIL   Вверх
yuliada
Дата 18.4.2009, 10:44 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 82
Регистрация: 16.2.2009
Где: Иркутск - San Die go

Репутация: нет
Всего: нет



Писали сами.

java version "1.6.0_13"
Java™ SE Runtime Environment (build 1.6.0_13-b03)
Java HotSpot™ 64-Bit Server VM (build 11.3-b02, mixed mode)

На -Xmx не реагирует, т.е. если поставить например 2Гб прога может отъесть и 4 и дальше продолжает расти.

Добавлено через 6 минут и 14 секунд
Т.е. в смысле растет память занимаемая процессом, размер heap стабильный.

Это сообщение отредактировал(а) yuliada - 18.4.2009, 10:45
PM MAIL   Вверх
powerOn
Дата 18.4.2009, 11:24 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


software saboteur
****


Профиль
Группа: Участник
Сообщений: 4367
Регистрация: 7.10.2005

Репутация: 47
Всего: 159



К сожалению с 64 битной VM мне не приходилось плотно работать, поэтому особенностей использования ею памяти я не знаю . Могу лишь посоветовать memory-monitoring программы с помощью той же VisualVM (или другим профайлером) с целью выяснения под какие объекты выделяется так много памяти. Возможно где-то в вашей программе имеется утечка.


--------------------
user posted image нет времени думать - нужно писать КОД!

PM MAIL   Вверх
yuliada
Дата 18.4.2009, 11:43 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 82
Регистрация: 16.2.2009
Где: Иркутск - San Die go

Репутация: нет
Всего: нет



Объекты я так поняла создаются в heap, а у нее размеры во время выполнения программы адекватные. Т.е. память ест сама JVM и ее надо мониторить? Что примерно может течь в JVM? Один из вариантов наверное потоки, но там их постоянное число...
PM MAIL   Вверх
powerOn
Дата 18.4.2009, 12:03 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


software saboteur
****


Профиль
Группа: Участник
Сообщений: 4367
Регистрация: 7.10.2005

Репутация: 47
Всего: 159



Если у Вас есть стойкая уверенность в том, что вашей программе нет утечки памяти, то возможно это баг JVM. Тут нужно посмотреть в сановском bug-database. Если так оно и есть, либо попробовать предыдущий апдейт JVM, либо ждать обновления. Еще можно посмотреть 32-битную версию...  

P.S: Кстати попробуйте 32-битную версию - будет ли она вести себя так же как и 64-битная.


--------------------
user posted image нет времени думать - нужно писать КОД!

PM MAIL   Вверх
yuliada
Дата 18.4.2009, 20:35 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 82
Регистрация: 16.2.2009
Где: Иркутск - San Die go

Репутация: нет
Всего: нет



Запустила на другой машинке с Win XP Home 32

java version "1.6.0_11"
Java™ SE Runtime Environment (build 1.6.0_11-b03)
Java HotSpot™ Client VM (build 11.0-b16, mixed mode, sharing)

Программка нормально отработала всю ночь. Когда запускаю на той другой машине (там Vista Entrprise 64 и JDK 1.6.0_13), то процесс постепенно отжирает все больше памяти.

Это сообщение отредактировал(а) yuliada - 18.4.2009, 20:47
PM MAIL   Вверх
powerOn
Дата 18.4.2009, 21:06 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


software saboteur
****


Профиль
Группа: Участник
Сообщений: 4367
Регистрация: 7.10.2005

Репутация: 47
Всего: 159



Скорее всего это баг JVM.


--------------------
user posted image нет времени думать - нужно писать КОД!

PM MAIL   Вверх
_and
Дата 20.4.2009, 04:29 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Java-developer
*


Профиль
Группа: Участник
Сообщений: 139
Регистрация: 6.8.2004
Где: Новокузнецк

Репутация: 1
Всего: 4



yuliada, попробуйте на предыдущих апдейтах 64-битной JVM позапускать может найдете именно тот который будет стабильно работать
PM MAIL ICQ Jabber   Вверх
yuliada
Дата 20.4.2009, 09:22 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 82
Регистрация: 16.2.2009
Где: Иркутск - San Die go

Репутация: нет
Всего: нет



Угу, уже попробовала. На апдейтах JDK1.6.0 с 10 по 13 жрет память, 8 и 9 нету, начиная с 7 работает нормально.

Это сообщение отредактировал(а) yuliada - 20.4.2009, 09:23
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Java"
LSD   AntonSaburov
powerOn   tux
javastic
  • Прежде, чем задать вопрос, прочтите это!
  • Книги по Java собираются здесь.
  • Документация и ресурсы по Java находятся здесь.
  • Используйте теги [code=java][/code] для подсветки кода. Используйтe чекбокс "транслит", если у Вас нет русских шрифтов.
  • Помечайте свой вопрос как решённый, если на него получен ответ. Ссылка "Пометить как решённый" находится над первым постом.
  • Действия модераторов можно обсудить здесь.
  • FAQ раздела лежит здесь.

Если Вам помогли, и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, LSD, AntonSaburov, powerOn, tux, javastic.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Java: Общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.0841 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.