![]() |
Модераторы: LSD, AntonSaburov |
![]() ![]() ![]() |
|
yuliada |
|
|||
Шустрый ![]() Профиль Группа: Участник Сообщений: 82 Регистрация: 16.2.2009 Где: Иркутск - San Die go Репутация: нет Всего: нет |
Есть некоторая программка, грузит в базу данные. В task manager видно, что память, занимаемая этим процессом постоянно растет, пока не съедается вообще все что можно. Но в VisualVM видно что Heap при этом остается адекватных размеров и не растет. Т.е. после того как прога достаточно долго работает размер Heap может быть например 800мб, а task manager показывает размер процесса 3Гб и продолжает расти. Почему это может быть и как с этим бороться?
Это сообщение отредактировал(а) yuliada - 18.4.2009, 04:06 |
|||
|
||||
yuliada |
|
|||
Шустрый ![]() Профиль Группа: Участник Сообщений: 82 Регистрация: 16.2.2009 Где: Иркутск - San Die go Репутация: нет Всего: нет |
Никакие потоки не создаются, т.е. количество потоков постоянное и тоже не растет.
Это сообщение отредактировал(а) yuliada - 18.4.2009, 09:34 |
|||
|
||||
powerOn |
|
|||
![]() software saboteur ![]() ![]() ![]() ![]() Профиль Группа: Участник Сообщений: 4367 Регистрация: 7.10.2005 Репутация: 47 Всего: 159 |
Программа в итоге падает с OutOfMemoryError?
|
|||
|
||||
yuliada |
|
|||
Шустрый ![]() Профиль Группа: Участник Сообщений: 82 Регистрация: 16.2.2009 Где: Иркутск - San Die go Репутация: нет Всего: нет |
Нет, не падает. Windows говорит что-то про low on memory и прибивает процесс, точно не помню, долго надо ждать чтобы всю память забить
|
|||
|
||||
powerOn |
|
|||
![]() software saboteur ![]() ![]() ![]() ![]() Профиль Группа: Участник Сообщений: 4367 Регистрация: 7.10.2005 Репутация: 47 Всего: 159 |
Программу вы сами писали? Версия JVM? Какое ограничение памяти установлено (опция -Xmx)?
|
|||
|
||||
yuliada |
|
|||
Шустрый ![]() Профиль Группа: Участник Сообщений: 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 |
|||
|
||||
powerOn |
|
|||
![]() software saboteur ![]() ![]() ![]() ![]() Профиль Группа: Участник Сообщений: 4367 Регистрация: 7.10.2005 Репутация: 47 Всего: 159 |
К сожалению с 64 битной VM мне не приходилось плотно работать, поэтому особенностей использования ею памяти я не знаю . Могу лишь посоветовать memory-monitoring программы с помощью той же VisualVM (или другим профайлером) с целью выяснения под какие объекты выделяется так много памяти. Возможно где-то в вашей программе имеется утечка.
|
|||
|
||||
yuliada |
|
|||
Шустрый ![]() Профиль Группа: Участник Сообщений: 82 Регистрация: 16.2.2009 Где: Иркутск - San Die go Репутация: нет Всего: нет |
Объекты я так поняла создаются в heap, а у нее размеры во время выполнения программы адекватные. Т.е. память ест сама JVM и ее надо мониторить? Что примерно может течь в JVM? Один из вариантов наверное потоки, но там их постоянное число...
|
|||
|
||||
powerOn |
|
|||
![]() software saboteur ![]() ![]() ![]() ![]() Профиль Группа: Участник Сообщений: 4367 Регистрация: 7.10.2005 Репутация: 47 Всего: 159 |
Если у Вас есть стойкая уверенность в том, что вашей программе нет утечки памяти, то возможно это баг JVM. Тут нужно посмотреть в сановском bug-database. Если так оно и есть, либо попробовать предыдущий апдейт JVM, либо ждать обновления. Еще можно посмотреть 32-битную версию...
P.S: Кстати попробуйте 32-битную версию - будет ли она вести себя так же как и 64-битная. |
|||
|
||||
yuliada |
|
|||
Шустрый ![]() Профиль Группа: Участник Сообщений: 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 |
|||
|
||||
powerOn |
|
|||
![]() software saboteur ![]() ![]() ![]() ![]() Профиль Группа: Участник Сообщений: 4367 Регистрация: 7.10.2005 Репутация: 47 Всего: 159 |
Скорее всего это баг JVM.
|
|||
|
||||
_and |
|
|||
![]() Java-developer ![]() Профиль Группа: Участник Сообщений: 139 Регистрация: 6.8.2004 Где: Новокузнецк Репутация: 1 Всего: 4 |
yuliada, попробуйте на предыдущих апдейтах 64-битной JVM позапускать может найдете именно тот который будет стабильно работать
|
|||
|
||||
yuliada |
|
|||
Шустрый ![]() Профиль Группа: Участник Сообщений: 82 Регистрация: 16.2.2009 Где: Иркутск - San Die go Репутация: нет Всего: нет |
Угу, уже попробовала. На апдейтах JDK1.6.0 с 10 по 13 жрет память, 8 и 9 нету, начиная с 7 работает нормально.
Это сообщение отредактировал(а) yuliada - 20.4.2009, 09:23 |
|||
|
||||
![]() ![]() ![]() |
Правила форума "Java" | |
|
Если Вам помогли, и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, LSD, AntonSaburov, powerOn, tux, javastic. |
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей) | |
0 Пользователей: | |
« Предыдущая тема | Java: Общие вопросы | Следующая тема » |
|
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности Powered by Invision Power Board(R) 1.3 © 2003 IPS, Inc. |