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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> java max heap size 
:(
    Опции темы
gelo86
Дата 8.5.2010, 14:04 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



Добрый день. Какое максималное значение может принимать параметры -Xmx -Xms на 32 и 64 битовых платформах ? Как я знаю самая большая проблема на 32 битовых архитектурах. Может знаете линк где почитать об етом ?
PM MAIL   Вверх
dorogoyIV
Дата 8.5.2010, 16:33 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1503
Регистрация: 26.3.2007

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



я вообще то не знаю конкретно для JVM, зато на винде раздувал файл подкачки с 1,5 Гб до 4,5 Гб с помощью Java.
то бишь  - не важно, что за JVM стоит на машине, главное чтобы ОС не упала

Это сообщение отредактировал(а) dorogoyIV - 8.5.2010, 16:34
PM MAIL   Вверх
Skynin
Дата 8.5.2010, 19:21 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



Сколько раз слышал эту байку, так и не довелось увидеть такого.
Есть под рукой пример кода, как добиться такого раздувания свопа с помощью Java?

Запустить надцать приложений с указанием отхватывать по 700 Мб и каждое чтобы реально и забирало всю память?
Таким способом любое приложение раздует своп.

Цитата

 Какое максималное значение может принимать параметры -Xmx -Xms на 32 и 64 битовых платформах ? Как я знаю самая большая проблема на 32 битовых архитектурах. 

Один 32ух-разрядный экземпляр JVM может в сумме - служебные данные плюс данные приложения - забрать не более 2ух Мб

Собственно 32ух-разрядные версии до XP (и она, кажется тоже) и не позволяли любому 32ух разрядному приложению запросить более 2ух Мб

Про линух и ограничения JVM под ним не уточнял.

Для серверных приложений все равно используются 64ех разрядные и линух и JVM.

Это сообщение отредактировал(а) Skynin - 8.5.2010, 19:26
PM MAIL WWW ICQ Skype GTalk YIM MSN   Вверх
dorogoyIV
Дата 9.5.2010, 10:02 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1503
Регистрация: 26.3.2007

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



Цитата(Skynin @  8.5.2010,  19:21 Найти цитируемый пост)
Есть под рукой пример кода, как добиться такого раздувания свопа с помощью Java?

по неопытности, делал javadocs с помощью java, потом махнул рукой, и стал делать с помощью винды (бат файл, в нем команды)
(используя джава, файл подкачки раздувался...)
PM MAIL   Вверх
BlackCrow
Дата 18.5.2010, 17:00 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



Цитата(Skynin @  8.5.2010,  19:21 Найти цитируемый пост)
Один 32ух-разрядный экземпляр JVM может в сумме - служебные данные плюс данные приложения - забрать не более 2ух Мб

а можно чуть чуть подробнее забрать откуда?
мне из личного опыта надо было в жвм передать два массива по 16 млн эелемнтов типа дабл спокойно жвм на винде раздулась до 512мб
PM MAIL   Вверх
LSD
Дата 19.5.2010, 13:17 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


Профиль
Группа: Модератор
Сообщений: 15718
Регистрация: 24.3.2004
Где: Dublin

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



Why can't I get a larger heap with the 32-bit JVM?
Цитата
The maximum theoretical heap limit for the 32-bit JVM is 4G. Due to various additional constraints such as available swap, kernel address space usage, memory fragmentation, and VM overhead, in practice the limit can be much lower. On most modern 32-bit Windows systems the maximum heap size will range from 1.4G to 1.6G. On 32-bit Solaris kernels the address space is limited to 2G. On 64-bit operating systems running the 32-bit VM, the max heap size can be higher, approaching 4G on many Solaris systems.

As of Java SE 6, the Windows /3GB boot.ini feature is not supported.

If your application requires a very large heap you should use a 64-bit VM on a version of the operating system that supports 64-bit applications. See Java SE Supported System Configurations for details.


Добавлено через 2 минуты и 22 секунды
Так что кучу больше, чем на 2Гб не раздуть (и то не на всех ОС). И вообще любое 32-х битное приложение под Windows никак больше 2Гб памяти не выделит.


--------------------
Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it.
PM MAIL WWW   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Java"
LSD   AntonSaburov
powerOn   tux
javastic
  • Прежде, чем задать вопрос, прочтите это!
  • Книги по Java собираются здесь.
  • Документация и ресурсы по Java находятся здесь.
  • Используйте теги [code=java][/code] для подсветки кода. Используйтe чекбокс "транслит", если у Вас нет русских шрифтов.
  • Помечайте свой вопрос как решённый, если на него получен ответ. Ссылка "Пометить как решённый" находится над первым постом.
  • Действия модераторов можно обсудить здесь.
  • FAQ раздела лежит здесь.

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

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


 




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


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

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