it-swarm-ru.tech

Любая выгода или ущерб от удаления файла подкачки на 8 ГБ RAM машине?

Я использую Windows 7 на двухъядерном процессоре x64 AMD с 8 ГБ оперативной памяти.

Мне даже нужен файл подкачки?

Поможет ли это удалить или ухудшить производительность?

Будет ли иметь значение, если это сервер или рабочий стол?

Есть ли разница между Windows 7 и Windows 2008 с файлом подкачки?

213
Jason

TL; DR версия: пусть Windows обрабатывает ваши настройки памяти/файла подкачки. Люди в MS потратили много больше часов на размышления над этими вопросами, чем большинство из нас, сисадминов.

Многие люди, кажется, предполагают, что Windows помещает данные в файл подкачки по требованию. EG: что-то требует много памяти, и не хватает RAM, чтобы удовлетворить потребность, поэтому Windows начинает безумно записывать данные с RAM на диск в этом в последнюю минуту, так что он может освободить RAM для новых требований.

Это неверно Там больше происходит под капотом. Вообще говоря, Windows поддерживает резервное хранилище , что означает, что она хочет видеть все, что находится в памяти, также где-то на диске. Теперь, когда что-то приходит и требует много памяти, Windows может очистить RAM) очень быстро, потому что эти данные уже на диске, готовый к переносу обратно в RAM, если это необходимо. Поэтому можно сказать, что большая часть того, что находится в файле подкачки, также в RAM; данные были предварительно помещены в файл подкачки для ускорения new требования к выделению памяти.

Для описания конкретных задействованных механизмов потребуется много страниц (см. Главу 7 из Windows Internals и обратите внимание, что новая редакция скоро будет доступна), но есть несколько приятных вещей отметить. Во-первых, многое из того, что находится в RAM по сути уже находится на диске - программный код извлекается из исполняемого файла или, например, DLL). необходимо записать в файл подкачки; Windows может просто отслеживать, откуда изначально были получены биты. Во-вторых, Windows отслеживает, какие данные в RAM наиболее часто используются, и поэтому очищается от RAM те данные, которые дольше всех остались без доступа.

Полное удаление файла подкачки может привести к перегрузке диска. Представьте себе простой сценарий, когда некоторые приложения запускаются и требуют 80% существующей оперативной памяти. Это вынудит текущий исполняемый код из RAM - возможно, даже кода ОС. Теперь каждый раз, когда этим другим приложениям - или самой ОС (!!) требуется доступ к этим данным, ОС должна просматривать их из резервного хранилища на диске, что приводит к значительному перерасходу, поскольку без файла подкачки, служащего резервным хранилищем для переходных данных, единственными вещами, которые могут быть выгружены, являются исполняемые файлы и библиотеки DLL, для которых изначально были созданы собственные резервные хранилища.

Конечно, существует множество сценариев использования ресурсов. Не исключено, что у вас есть один из сценариев, при котором не будет побочных эффектов от удаления файла подкачки, но это меньшинство. В большинстве случаев удаление или уменьшение файла подкачки приведет к снижению производительности в сценариях пикового использования ресурсов.

Некоторые ссылки:

отметил dmo недавний пост Эрика Липперта , который помогает в понимании виртуальной памяти (хотя и менее связан с вопросом). Я помещаю это здесь, потому что я подозреваю, что некоторые люди не будут прокручивать вниз к другим ответам - но если вы находите это ценным, вы должны dmo голосовать так что используйте ссылка чтобы попасть туда!

302
quux

Эрик Липперт недавно написал запись в блоге о том, как Windows управляет памятью. Короче говоря, модель памяти Windows можно рассматривать как хранилище дисков, где RAM действует как кэш, повышающий производительность).

80
dmo

Как видно из других ответов, я единственный, кто отключил файл подкачки и никогда не сожалел об этом. Отлично: -)

И дома, и на работе у меня Vista 64-битная с 8 ГБ оперативной памяти. У обоих файл подкачки отключен. На работе для меня нет ничего необычного в том, чтобы иметь несколько экземпляров Visual Studio 2008, Virtual PC с Windows XP, 2 экземпляра SQL Server и Internet Explorer 8 с множеством вкладок, работающих вместе. Я редко достигаю 80% памяти.

Я также использую гибридный сон каждый день (спячка со сном) без каких-либо проблем.

Я начал экспериментировать с ним, когда у меня была Windows XP с 2 ГБ RAM), и я действительно увидел разницу. Классический пример был, когда перестали отображаться значки в панели управления Сам по себе, один за другим, но сразу. Также резко возросло время запуска Firefox/Thunderbird. Все стало работать сразу после того, как я нажал на что-то. К сожалению, 2 ГБ было слишком мало для моих приложений (Visual Studio 2008, Virtual PC и SQL Server ), поэтому я включил его обратно.

Но сейчас с 8 ГБ я никогда не хочу возвращаться и включать файл подкачки.

Для тех, кто говорит о крайних случаях, возьмите это из моего Windows XP раз).
Когда вы пытаетесь загрузить большую сводную таблицу в Excel из запроса SQL, Excel 2000 довольно быстро увеличивает потребление памяти.
Если у вас отключен файл подкачки - подождите немного, а затем Excel взорвется, и система очистит всю память после него.
Когда у вас включен файл подкачки - вы ждете некоторое время, и когда вы заметите, что что-то не так, вы почти ничего не можете сделать с вашей системой. Ваш жесткий диск работает как ад, и даже если вам как-то удастся запустить диспетчер задач (после нескольких минут ожидания) и убить Excel.exe Вы должны подождать минуту или около того, пока система не загрузит все обратно из файла подкачки.
Как я увидел позже, Excel 2003 обрабатывает одну и ту же сводную таблицу без каких-либо проблем с отключенным файлом подкачки - так что это не было "слишком большой проблемой набора данных".

Так что, на мой взгляд, отключенный файл подкачки даже иногда защищает вас от плохо написанных приложений.

Коротко: если вам известно об использовании памяти - вы можете безопасно отключить ее.

Edit: Я просто хочу добавить, что я установил Windows Vista SP2 без проблем.

48
SeeR

Вы можете сделать некоторые измерения, чтобы понять, как ваша собственная система использует память, прежде чем вносить изменения в файл подкачки. Или (если вы все еще хотите внести коррективы), до и после упомянутых корректировок.

Perfmon является инструментом для этого; нет Диспетчер задач. Счетчик клавиш Память - Ввод страниц/сек. Это, в частности, будет отображать жесткие сбои страниц, на которых требуется чтение с диска, прежде чем процесс может быть продолжен. Мягкие сбои страницы (которые представляют собой большинство элементов, отображаемых по умолчанию Page Faults/sec counter; Я рекомендую игнорировать этот счетчик!) На самом деле не проблема; они просто показывают элементы, считываемые из RAM нормально.

граф Perfmon http://g.imagehost.org/0383/perfmon-paging.png

Выше приведен пример системы без забот о памяти. Очень редко наблюдается резкий сбой - их нельзя избежать, так как жесткие диски всегда больше оперативной памяти. Но график в значительной степени плоский в нуле. Таким образом, ОС редко загружает данные из резервного хранилища.

Если вы видите график Memory - Pages Input/sec, который намного шире, чем этот, правильный ответ - либо уменьшить использование памяти (запустить меньше программ), либо добавить RAM. Изменение настроек вашего файла подкачки не изменит того факта, что от системы требуется больше памяти, чем на самом деле.

Удобный дополнительный счетчик для мониторинга: PhysicalDisk - Avg. Длина очереди (все экземпляры). Это покажет, насколько ваши изменения влияют на использование самого диска. Система с хорошим поведением покажет среднее значение этого счетчика на уровне 4 или меньше на шпиндель.

35
quux

Я годами запускаю свою 8-Гбайт Vista x64 коробку без файла подкачки, без каких-либо проблем.

Проблемы действительно возникали, когда я действительно использовал свою память!

Три недели назад я начал редактировать действительно большие файлы изображений (~ 2 ГБ) в Photoshop. Один сеанс редактирования съел всю мою память. Проблема: Я не смог сохранить свою работу, поскольку Photoshop требуется больше памяти для сохранения файла!

И поскольку это был сам Photoshop, который поглощал всю память, я даже не мог освободить память, закрывая программы (ну, я сделал, но это было слишком мало, чтобы помочь).

Все, что я мог сделать, это отказаться от своей работы, включить файл подкачки и повторить всю свою работу - из-за этого я потерял много работы и не могу рекомендовать отключение файла подкачки.

Да, большую часть времени он будет отлично работать. Но в тот момент, когда он сломается, может быть больно.

34
Sam

Несмотря на то, что ответы здесь достаточно хорошо охватили тему, я все же рекомендую прочитать это:

http://blogs.technet.com/markrussinovich/archive/2008/11/17/3155406.aspx

Он говорит о размере ПФ почти в конце:

Некоторые считают, что отсутствие файла подкачки приводит к повышению производительности, но в целом наличие файла подкачки означает, что Windows может записывать страницы в измененном списке (которые представляют страницы, к которым нет активного доступа, но которые не были сохранены на диск) на файл подкачки, что делает эту память доступной для более полезных целей (процессов или файлового кэша). Таким образом, хотя могут быть некоторые рабочие нагрузки, которые работают лучше без файла подкачки, в общем, наличие одного из них будет означать, что системе будет доступно больше используемой памяти (не говоря уже о том, что Windows не сможет записывать дампы ядра без большого размера файла подкачки). хватит их держать).

Мне очень нравятся статьи Марка.

19
Radim Cernej

Лучший ответ, который я могу придумать, заключается в том, что при нормальной нагрузке вы не можете использовать 8 ГБ, но это неожиданные нагрузки, которые могут привести к проблемам.

С файлом подкачки система будет по крайней мере работать медленно, как только она начнет попадать на страницу. Но если вы удалите файл подкачки, он просто умрет (насколько я знаю).

Кроме того, 8 ГБ сейчас кажутся большими, но через несколько лет это можно считать минимальным объемом памяти для большого количества программного обеспечения.

В любом случае - я бы порекомендовал сохранить хотя бы небольшой файл подкачки; но другие, пожалуйста, поправьте меня, если я вне базы.

13
Dave Drager

Вы не упомянули, является ли это 64-битной версией Windows, но я думаю, что да.

Файл подкачки служит многим вещам, включая создание дампа памяти в случае BSoD (Синий экран смерти).

Если у вас нет файла подкачки, Windows не сможет вывести страницу на диск, если недостаточно памяти. Вы можете подумать, что с 8 ГБ вы не достигнете этого предела. Но у вас могут быть плохие программы с утечкой памяти со временем.

Я думаю, что это не позволит вам перейти в спящий/ждущий режим без файла подкачки (но я еще не пробовал).

Windows 7/2008/Vista не меняет использование файла подкачки.

Я видел одно объяснение Марка Руссиновича (Microsoft Fellow), объясняющего, что Windows может работать медленнее без файла подкачки, чем с файлом подкачки (даже с большим количеством оперативной памяти). Но я не могу найти основную причину.

Вам не хватает места на диске? Я бы оставил минимум 1 ГБ, чтобы иметь возможность получить дамп ядра в случае BSoD.

6
Mathieu Chateau

Единственный человек, который может сказать вам, если ваш сервер или рабочая станция "нуждаются" в файле подкачки - это вы, с осторожным использованием системного монитора или того, как он называется в наши дни. Какие приложения вы используете, какое использование они видят, и какое максимальное возможное использование памяти вы можете увидеть?

Стоит ли рисковать стабильностью ради экономии небольшого количества денег на маленьких жестких дисках?

Что происходит, когда вы загружаете очень большой патч, скажем, пакет обновления. Если служба установки решит, что ей нужно больше памяти, чем вы предполагали, чтобы распаковать патч, что тогда? Если ваш антивирусный сканер (по праву) решит сканировать этот очень большой пакет, какое использование памяти ему потребуется, пока он распаковывает и сканирует этот файл исправлений - я надеюсь, что файл архива исправлений не содержит никаких архивов сам по себе, потому что это абсолютно Убийство использует цифры памяти.

То, что я могу сказать вам, это то, что удаление вашего файла подкачки имеет гораздо большую вероятность причинить вред, чем помочь. Я не вижу причины, по которой у вас такого не будет - я уверен, что может быть несколько случаев, когда я ошибаюсь в этом, но это совсем другая область.

5
Rob Moir

Я отключил файл подкачки (8 ГБ на ноутбуке с архитектурой x86), и у меня возникли две проблемы, даже если на нем было 2500 МБ:

  1. Ошибка ASP.NET при попытке активировать службу WCF : проверка шлюзов памяти не удалась, так как объем свободной памяти (399 556 608 байт) составляет менее 5% от общего объема памяти. В результате сервис не будет доступен для входящих запросов. Чтобы решить эту проблему, либо уменьшите нагрузку на компьютер, либо измените значение minFreeMemoryPercentageToActivateService в элементе конфигурации serviceHostingEnvironment.

    Сколько 3,7 ГБ меньше, чем 5% от 8 ГБ, я никогда не узнаю !!

  2. Получение Закрытие программ для предотвращения потери информации диалоговое окно: Когда используется 75% моего RAM), я получаю диалоговое окно с сообщением мне закрыть программы. Вы можете отключить это с помощью изменения реестра (или возможно, отключив "Службу политики диагностики").

В конце концов я решил снова включить его. Windows просто-напросто никогда не была разработана для использования без файла подкачки. Он оптимизирован для работы с пейджингом, а не без него. Если вы планируете использовать более 75% памяти и не хотите связываться с реестром - тогда это может быть не для вас.

5
Simon

Похоже, что многие сильно ограниченные люди имеют мнение по этому вопросу, но на самом деле никогда не пытались запустить свой компьютер без файла подкачки.

Мало, если не почти, пытались. Кажется, еще меньше знают, как Windows обрабатывает файл подкачки. Он не "просто" заполняется, когда у вас заканчивается физическая память. Могу поспорить, что большинство из вас даже не знали, что ваше "свободное" RAM используется в качестве файлового кэша!

Вы МОЖЕТЕ получить значительные улучшения производительности, отключив файл подкачки. Ваша система будет более восприимчива к ошибкам нехватки памяти (и знаете ли вы, как ваши приложения реагируют в этом сценарии - по большей части ОС просто закрывает приложение). Время запуска из режима ожидания или длительных периодов простоя будет намного быстрее.

Если бы Microsoft фактически разрешила вам установить опцию, в соответствии с которой файл подкачки будет использоваться ТОЛЬКО при отсутствии физического RAM (и все файловые буферы были отброшены), тогда я думаю, что отключение было мало файл подкачки.

2
PP.

Ваша общая доступная память - ваш файл подкачки + фактическая память.

Ключевой вопрос заключается в том, приближается ли ожидаемое суммарное использование памяти для всех приложений и операционной системы к 8 ГБ. Если ваше среднее использование памяти составляет 2 ГБ, а максимальное использование памяти - всего 4 ГБ, тогда файл подкачки не имеет смысла. Если ваше максимальное использование памяти ближе к 6-7 Гб или больше, лучше иметь файл подкачки.

PS: не забудьте учесть рост в будущем!

2
John Lim