This Microsoft article — How to determine the appropriate page file size for 64-bit versions of Windows Server 2008 and or Windows 2008 R2 provides guidance for calculating the page file size for 64 bit Windows 2008 and Windows 2008R2. This no doubt works fine for general purpose servers. I’m wondering what the guidance is for SQL Server 2008R2 running on Windows 2008/R2 64 bit?
I’m presuming we want as little in memory data to be hitting the page file otherwise SQL could be hitting the disk twice for data. Does SQL Server even allow data in memory to hit the page file? I’ve hunted through SQL Server 2008 R2 Books Online for guidance but haven’t yet found any mention of page file use.
Here’s a potential usage scenario: Given a physical server with 64GB of RAM, is a pagefile necessary for the entire 64GB of RAM? Should we gear it up for 96GB of pagefile? That does seem a bit excessive for a single file. I know conventional wisdom has been that Windows couples pagefile to memory in an attempt to make swapping out apps easier on RAM, but is that true? Will a less than 64GB pagefile hinder performance here?
Leigh Riffel
23.7k16 gold badges76 silver badges148 bronze badges
asked Jun 15, 2011 at 14:17
0
There are no special settings for SQL Server which only uses physical memory normally
Just do what MS say for Windows and that’s it
Oh, and buy more RAM anyway while we’re one the subject…
answered Jun 15, 2011 at 14:21
gbngbn
69.3k8 gold badges160 silver badges240 bronze badges
0
Look into lock pages in memory
. This way, you can give preference for your SQL service account to use available RAM rather than paging to disk. To read more on lock pages in memory, check this link. A snippet follows:
The Windows policy Lock Pages in Memory option is disabled by default. This privilege must be enabled to configure Address Windowing Extensions (AWE). This policy determines which accounts can use a process to keep data in physical memory, preventing the system from paging the data to virtual memory on disk. On 32-bit operating systems, setting this privilege when not using AWE can significantly impair system performance. Locking pages in memory is not required on 64-bit operating systems.
Please test this feature before using on your systems.
answered Jun 15, 2011 at 18:13
StanleyJohnsStanleyJohns
5,9322 gold badges20 silver badges44 bronze badges
1
Yes, for 64GB RAM you need at least 64GB swap file (96GB recommended). Not because of potential swapping, but because of the design of the Windows Memory Manager. I’ve wrote about this issue before in System pagefile size on machines with large RAM:
When a process asks for
MEM_COMMIT
memory via
VirtualAlloc
/VirtualAllocEx
, the requested size needs to be reserved
in the pagefile. This was true in the first Win NT system, and is
still true today see Managing Virtual Memory in Win32:When memory is committed, physical pages of memory are allocated and space is reserved in a pagefile.
The alternative would be something like the oom_killer.
So do follow the recommendation, sometimes things are a bit more complex than they look. And I haven’t even touched the complications brought by AWE and the lock pages privilege…
answered Aug 6, 2011 at 17:24
Remus RusanuRemus Rusanu
51.4k3 gold badges93 silver badges171 bronze badges
5
This Microsoft article — How to determine the appropriate page file size for 64-bit versions of Windows Server 2008 and or Windows 2008 R2 provides guidance for calculating the page file size for 64 bit Windows 2008 and Windows 2008R2. This no doubt works fine for general purpose servers. I’m wondering what the guidance is for SQL Server 2008R2 running on Windows 2008/R2 64 bit?
I’m presuming we want as little in memory data to be hitting the page file otherwise SQL could be hitting the disk twice for data. Does SQL Server even allow data in memory to hit the page file? I’ve hunted through SQL Server 2008 R2 Books Online for guidance but haven’t yet found any mention of page file use.
Here’s a potential usage scenario: Given a physical server with 64GB of RAM, is a pagefile necessary for the entire 64GB of RAM? Should we gear it up for 96GB of pagefile? That does seem a bit excessive for a single file. I know conventional wisdom has been that Windows couples pagefile to memory in an attempt to make swapping out apps easier on RAM, but is that true? Will a less than 64GB pagefile hinder performance here?
Leigh Riffel
23.7k16 gold badges76 silver badges148 bronze badges
asked Jun 15, 2011 at 14:17
0
There are no special settings for SQL Server which only uses physical memory normally
Just do what MS say for Windows and that’s it
Oh, and buy more RAM anyway while we’re one the subject…
answered Jun 15, 2011 at 14:21
gbngbn
69.3k8 gold badges160 silver badges240 bronze badges
0
Look into lock pages in memory
. This way, you can give preference for your SQL service account to use available RAM rather than paging to disk. To read more on lock pages in memory, check this link. A snippet follows:
The Windows policy Lock Pages in Memory option is disabled by default. This privilege must be enabled to configure Address Windowing Extensions (AWE). This policy determines which accounts can use a process to keep data in physical memory, preventing the system from paging the data to virtual memory on disk. On 32-bit operating systems, setting this privilege when not using AWE can significantly impair system performance. Locking pages in memory is not required on 64-bit operating systems.
Please test this feature before using on your systems.
answered Jun 15, 2011 at 18:13
StanleyJohnsStanleyJohns
5,9322 gold badges20 silver badges44 bronze badges
1
Yes, for 64GB RAM you need at least 64GB swap file (96GB recommended). Not because of potential swapping, but because of the design of the Windows Memory Manager. I’ve wrote about this issue before in System pagefile size on machines with large RAM:
When a process asks for
MEM_COMMIT
memory via
VirtualAlloc
/VirtualAllocEx
, the requested size needs to be reserved
in the pagefile. This was true in the first Win NT system, and is
still true today see Managing Virtual Memory in Win32:When memory is committed, physical pages of memory are allocated and space is reserved in a pagefile.
The alternative would be something like the oom_killer.
So do follow the recommendation, sometimes things are a bit more complex than they look. And I haven’t even touched the complications brought by AWE and the lock pages privilege…
answered Aug 6, 2011 at 17:24
Remus RusanuRemus Rusanu
51.4k3 gold badges93 silver badges171 bronze badges
5
- Remove From My Forums
-
Общие обсуждения
-
Есть сервер Windows 2008 R2 Enterprise
на борту 256GB ОЗУ, но нет возможности подключить большой диск, установили лимит файла подкачки до 15GB, сейчас возникли проблемы что некоторые приложения отказываются запускаться из-за нехватки виртуальной памяти, и это при том что еще больше половины физической
памяти свободно согласно данным в Мониторе ресурсов.вопрос: как можно объяснить такое поведение системы. и как можно избавиться от такого ?
-
Изменен тип
15 июня 2012 г. 12:09
-
Изменен тип
Наверняка каждый пользователь сталкивался с ситуацией, когда компьютеру для нормальной работы не хватает оперативной памяти, вследствие чего операционная система обращается за помощью к так называемой виртуальной памяти, чтобы восполнить данную нехватку. О том, что такое виртуальная память, и как ее увеличить и читайте в данной статье.
0. Виртуальная память, что это такое?
Под понятием виртуальная память следует понимать сочетание памяти временного хранилища и оперативного запоминающего устройства (ОЗУ) на жестком диске (винчестере).
В том случае, когда все работающие на компьютере программы полностью занимают ОЗУ, оперативная память захватывает часть пространства на винчестере и создает там, так называемый, файл подкачки. Сразу же после перемещения информационных данных в этот файл, оперативная память освобождается. Этого достаточно для выполнения операций. Программы не «видят» разницы между виртуальной и оперативной памятью, единственным отличием является то, что настоящая оперативная память может обеспечивать значительно меньшее время доступа, нежели виртуальная.
1. Влияние ОЗУ на скорость работы программ
Скорость работы всех программ во многом зависит от объема оперативной памяти, проще говоря, чем больше объем ОЗУ, установленного в компьютере, тем быстрее эти программы работают. Если вследствие нехватки оперативной памяти работа компьютера замедляется, то ее следует восполнить путем увеличения размера виртуальной памяти на винчестере. Однако здесь следует учитывать, что данные с ОЗУ считываются быстрее, нежели с жесткого диска. Потому предпочтительнее будет добавить ОЗУ.
2. Увеличение виртуальной памяти
Если всплывает окно с сообщением об ошибках, вызванных недостаточным размером виртуальной памяти, следует выполнить одно из двух действий, либо увеличить размер файла подкачки, либо добавить ОЗУ.
Как правило, операционная система автоматически меняет размер файла подкачки. Однако если размер этого файла все же недостаточный для правильной работы компьютера, то его можно увеличить вручную.
Чтобы это осуществить, необходимо выполнить следующие действия:
В Windows XP: Необходимо правой кнопкой мышки щелкнуть на значок «Мой компьютер» после чего перейти по пункту «Свойства».
В Windows Vista и старше: Перейдем в «Панель управления» — «Система и безопасность» — «Система» — «Дополнительные параметры системы»
Откроется окно «Свойства системы». Перейдем на вкладку «Дополнительно» и нажмем «Параметры» быстродействия.
Откроется окошко, в котором нужно выбрать вкладку «Дополнительно», затем нажать «Изменить» в группе «Виртуальная память».
Снимем флаг «Автоматически выбирать объем файла подкачки» и, выбрав диск, с которого будет осуществляться подкачка файла, устанавливаем значения исходного и максимального размеров виртуальной памяти. Необходимо в исходный размер записать рекомендуемое число, а в максимальном размере установить большое значение, например число 7000. После этого нажать на кнопку «Задать».
После этого следует принять все изменения, нажав в каждом окне кнопку «Ок» и перезагрузить компьютер.
Размер файла подкачки принято связывать с объемом физической оперативной памяти компьютера
В. Каков оптимальный размер файла подкачки?
О. . Как правило, рекомендуется, чтобы размер файла подкачки был в полтора раза больше общего объема системной памяти. В действительности, чем больше оперативная память компьютера, тем меньше потребность в файлах подкачки. Размер файла подкачки следует выбирать с учетом максимального количества выделенной памяти. Размер файла подкачки должен равняться пиковому значению выделения (в случае маловероятной ситуации, если все выделенные страницы записываются в файл подкачки на диске).
В Windows XP и Windows Server 2003 пиковое значение можно найти на вкладке Performance диспетчера задач. Однако этот параметр в Windows Server 2008 и Windows Vista отсутствует. Определить пиковые значения выделения памяти Windows Server 2008 и Windows Vista можно двумя способами:
1. Загрузите Process Explorer из Web-страницы «Process Explorer v11.21» компании Microsoft. Вам потребуется программа, пригодная для открытия ZIP-архивов, таких как WinZip и ZipGenius. Откройте ZIP-файл и дважды щелкните на файле procexp.exe. Щелкните View на панели инструментов и выберите пункт System Information. В разделе Commit Charge (K) найдите пиковое значение, как показано на следующем экране:
2. Используйте системный монитор для записи значения счетчика Memory — Committed Bytes и просмотрите журнал в поисках значения Maximum.
Сервер должен работать со всеми предполагаемыми рабочими нагрузками, чтобы задействовать максимальный объем памяти в процессе мониторинга.
Виртуальная память позволяет расширить объем доступной оперативной памяти (RAM) за счет дискового пространства. Эта возможность впервые появилась в процессорах Intel 386. Запись содержимого RAM на диски называется подкачкой. Определенный объем памяти, скажем, 1024 Мб, записывается на диск в виде файла. При необходимости обращения к нему чтение осуществляется с диска, а не из физической RAM.
Исходный файл подкачки автоматически создается на диске, содержащем операционную систему. По умолчанию на других дисках файлов подкачки нет. Если они нужны, вам придется создать их вручную. Создавая файл подкачки, вы задаете начальный и максимальный размеры. Файлы подкачки записываются на том под именем PAGEFILE.SYS.
Чтобы вручную сконфигурировать виртуальную память, выполните следующие действия:
1. Перейдите на вкладку Дополнительно (Advanced) диалогового окна Свойства системы (System Properties) и щелкните кнопку Параметры (Settings) в разделе Быстродействие (Performance). Откроется диалоговое окно Параметры быстродействия (Performance Options). Тут Вы так же сможете найти счетчик посещаемости сайта, если Ваш сервер так же имеет Веб-интерфейс и счётчик настроен.
2. В диалоговом окне Параметры быстродействия (Performance Options) перейдите на вкладку Дополнительно (Advanced). Щелкните кнопку Изменить (Change), чтобы открыть диалоговое окно Виртуальная память (Virtual Memory). На нем представлена следующая информация:
• Диск [Метка тома] (Drive [Volume Label]) и Файл подкачки (Мб) (Paging File Size (MB)) Текущие параметры виртуальной памяти. Каждый том выводится с соответствующим файлом подкачки (если он присутствует). Диапазон указывает значения начального и максимального размера, заданные для файла подкачки.
• Размер файла подкачки для каждого диска (Paging File Size For Each Drive) Здесь показаны сведения по выбранному диску, и задаются размеры файла подкачки на нем. В поле Свободно (Space Available) показано, сколько пространства доступно на диске.
• Общий объем файла подкачки на всех дисках (Total Paging File Size For All Drives) Рекомендуемый для системы размер виртуальной памяти и реальный объем, выделенный в данный момент. Если вы впервые настраиваете виртуальную память, обратите внимание, что файл рекомендуемого размера уже есть на системном диске (в большинстве случаев).
3. По умолчанию Windows Server 2008 управляет размером файла подкачки для всех дисков. Чтобы настроить виртуальную память вручную, сбросьте флажок Автоматически выбирать объем файла подкачки (Automatically Manage Paging File Size For All Drives).
4. В списке Диск (Drive) выберите том, с которым хотите работать.
5. Установите переключатель Указать размер (Custom Size) и заполните поля Исходный размер (Initial Size) и Максимальный размер (Maximum Size).
6. Щелкните кнопку Задать (Set) для сохранения изменений.
7. Повторите шаги 4-6 для каждого тома, который хотите сконфигурировать.
8. Щелкните ОК. Если на экране появится сообщение о перезаписи существующего файла PAGEFILE.SYS, щелкните Да (Yes).
9. Если вы, обновили настройки файла подкачки, который используется в данный момент, на экране появится сообщение о том, что изменения вступят в силу после перезагрузки системы. Щелкните ОК.
10. Дважды щелкните ОК, чтобы закрыть открытые диалоговые окна. Закрывая окно Система (System), вы увидите сообщение с запросом, хотите ли вы перезапустить систему. Щелкните Перезагрузить (Restart).
Чтобы Windows Server 2008 автоматически управляла виртуальной памятью, выполните следующие действия:
1. Перейдите на вкладку Дополнительно (Advanced) диалогового окна Свойства системы (System Properties) и щелкните кнопку Параметры (Settings) в разделе Быстродействие (Performance). Откроется диалоговое окно Параметры быстродействия (Performance Options).
2. В диалоговом окне Параметры быстродействия (Performance Options) перейдите на вкладку Дополнительно (Advanced). Щелкните кнопку Изменить (Change), чтобы открыть диалоговое окно Виртуальная память (Virtual Memory).
3. Установите флажок Автоматически выбирать объем файла подкачки (Automatically Manage Paging File Size For All Drives).
4. Трижды щелкните OK, чтобы закрыть открытые диалоговые окна.
Вопрос о размере файла подкачки довольно часто встречается на различных технических ресурсах, однако однозначных рекомендаций на этот счет нет. Попадаются как советы установить файл подкачки в 1.5-2 раза больше объема установленной памяти, так и полностью отключить его. И то и другое абсолютно бессмысленно с практической точки зрения. Поэтому сегодня речь пойдет о том, что такое файл подкачки (он же своп-файл, он же страничный файл) и как правильно выбрать и настроить его размер.
Чтобы понять, для чего нужен файл подкачки, стоит сначала разобраться в принципах работы памяти в Windows. Поэтому начнем с теории.
Виртуальная память
Как правило, говоря о памяти мы имеем в виду модули оперативной памяти, физически установленные на компьютере, или физическую память. Объем доступной физической памяти жестко ограничен и зависит от возможностей оборудования, разрядности операционной системы и условий лицензирования. Для того, чтобы обойти эти ограничения, в операционных системах Windows используется такой ресурс, как виртуальная память.
Операционная система Windows работает не с физической, а именно с виртуальной памятью. Технически виртуальная память состоит из физической памяти (ОЗУ) и специального файла(-ов) подкачки, объединенных в единое виртуальное адресное пространство. Для каждого запущенного процесса выделяется собственное, отдельное от других процессов адресное пространство в виртуальной памяти, в котором он выполняется и которым управляет. Для обращения к памяти используются указатели на адреса в виртуальном адресном пространстве, при этом сам процесс не в курсе 🙂 того, где именно хранятся его данные — в ОЗУ или в файле, это решает операционная система.
Максимально возможный объем доступной виртуальной памяти зависит от разрядности операционной системы. Так в 32-разрядной системе процесс может адресовать не более 4 гигабайт (232) памяти. Для 64-разрядного процесса теоретическое ограничение составляет 16 экзабайт (264), а практически в современных 64-разрядных версиях Windows поддерживается адресное пространство объемом до 16 терабайт.
Примечание. Некоторые 32-разрядные версии Windows Server используют технологию PAE, позволяющую адресовать до 64ГБ памяти. Подробнее о PAE можно узнать здесь.
В отличии от физической, виртуальная память имеет гораздо более гибкие ограничения. Это позволяет одновременно выполняться большому количеству процессов, которые не смогли бы поместиться в физической памяти. Таким образом, основная задача механизма виртуальной памяти — расширение доступной памяти компьютера.
Управление памятью происходит примерно так.
Виртуальное адресное пространство поделено на блоки равного размера, которые называют страницами (pages). Отсюда кстати и название pagefile — страничный файл. Физическая память также поделена на разделы, называемые страничными фреймами (page frames), которые используются для хранения страниц.
Каждому процессу при старте выделяется ″кусок″ адресного пространства в виртуальной памяти. Соответственно в каждый момент времени в памяти находятся страницы из виртуального адресного пространства каждого процесса. Страницы, находящиеся в физической памяти и доступные немедленно, называются действительными (valid pages), а страницы, которые в данный момент недоступны, например находящиеся на диске — недействительными (invalid pages).
При обращении процесса к странице памяти, помеченной как недействительная, происходит страничное прерывание (page fault). При возникновении прерывания диспетчер виртуальной памяти находит запрашиваемую страницу и загружает ее в свободный страничный фрейм физической памяти. Собственно этот процесс и называется подкачкой (paging).
При дефиците физической памяти диспетчер памяти выбирает фреймы, которые можно освободить и переносит их содержимое на диск, в файл подкачки. Принцип переноса такой: когда процесс использовал все выделенные ему фреймы, то при каждом страничном прерывании в этом процессе система удаляет из физической памяти одну из его страниц. Выбор страницы осуществляется по принципу первым пришел — первым ушел (first in, first out, FIFO), т.е. в файл подкачки переносится страница, дольше всех находившаяся в памяти.
У каждого процесса есть свой рабочий набор (working set) — набор страниц, находящихся в физической памяти. Рабочий набор определяет размер физической памяти, выделенной процессу, он имеет минимальный и максимальный размер. В момент запуска процессу назначается минимальный размер рабочего набора, т.е. минимальное количество страниц, которые гарантированно будут находится в оперативной памяти. При достаточном количестве свободной физической памяти процесс может увеличивать свой рабочий набор до размера, равного максимальному рабочему набору. Когда же начинается нехватка памяти, диспетчер виртуальной памяти начинает урезать рабочий набор всех процессов до минимального, удаляя лишние страницы из физической памяти.
После уменьшения рабочего набора процесса до минимума диспетчер памяти отслеживает страничные прерывания, генерируемые каждым процессом. При большом количестве прерываний диспетчер может увеличить размер рабочего набора процесса, при отсутствии — продолжает уменьшать рабочий набор до тех пор, пока не произойдет прерывание. Появление прерывания говорит о том, что достигнут минимальный размер памяти, необходимый процессу для работы. Таким образом достигается баланс между потреблением физической памяти и производительностью.
На самом деле это очень примерное описание работы виртуальной памяти, но для общего понимания его вполне хватит. Поэтому завязываем с теорией и переходим к практике.
Текущие настройки файла подкачки
Посмотреть текущий размер файла можно в оснастке Свойства системы (System Properties). Для этого надо нажать Win+R и выполнить команду sysdm.cpl. Затем перейти на вкладку «Advanced», в поле «Performance» нажать на кнопку «Settings» и в открывшемся окне перейти на вкладку «Advanced».
Здесь указан суммарный размер файла подкачки на всех дисках, а по кнопке «Change» можно перейти к его настройкам.
По умолчанию включено автоматическое управление размером файла подкачки. Это значит, что операционная система создает один файл подкачки pagefile.sys в корне системного диска и устанавливает его размер автоматически, исходя из своих потребностей.
Дамп памяти
Чтобы понять, чем руководствуется система при выборе размера файла подкачки, опять перейдем к теории и обратимся к такому понятию как дамп памяти (memory dump). Дело в том, что кроме расширения физической памяти файл подкачки имеет еще одно назначение — он используется при создании аварийных дампов памяти при сбоях системы. Происходит это следующим образом.
Во время загрузки операционная система создает карту секторов, занимаемых на диске файлом подкачки и сохраняет ее в памяти. При сбое системы проверяется целостность этой карты, драйвера диска и управляющей структуры дискового драйвера. Если целостность их не нарушена, то ядро системы вызывает специальные функции вводавывода, предназначенные для сохранения образа памяти после системного сбоя и записывает данные из памяти на диск, в файл подкачки, используя сохраненную карту секторов.
При следующей загрузке системы диспетчер сеанса (Session Manager Subsystem Service, SMSS) инициализирует файл подкачки и проверяет наличие в нем заголовка дампа. Если заголовок есть, то данные копируются из файла подкачки в файл аварийного дампа и делается соответствующая запись в системном журнале.
Соответственно при автоматическом управлении файлом подкачки система ориентируется на настройки создания аварийного дампа памяти, выбирая размер файла в соответствии с типом дампа:
• Полный дамп памяти (Complete memory dump) — в дамп записывается все содержимое оперативной памяти на момент сбоя, поэтому размер файла подкачки должен быть равен размеру физической памяти + 1Мб (для заголовка). Этот тип выбирается по умолчанию при количестве физической памяти меньше 4ГБ;
• Дамп памяти ядра (Kernel memory dump) — в дамп записывается только память, выделенная для ядра ОС, драйверов устройств и приложений, работающих в режиме ядра. Дамп ядра занимает гораздо меньше места, чем полный дамп, при этом его как правило достаточно для определения причин сбоя. Этот тип дампа выбирается по умолчанию для систем с объемом ОЗУ 4ГБ и более. Минимальный размер файла подкачки должен составлять примерно 1/3 от объема физической памяти;
• Малый дамп памяти (Small memory dump) — мини-дамп, в котором содержатся минимально необходимые данные: стоп-код и описание ошибки, список загруженных драйверов и информация о запущенных в момент сбоя процессах. Этот дамп требует файл подкачки не менее 2Мб;
• Автоматический дамп памяти (Automatic memory dump) — новый тип дампа, появившийся в Windows 8Server 2012 и более новых. На самом деле это тот же дамп ядра, единственная разница в том, что он позволяет системе динамически управлять размером файла подкачки, выбирая наиболее оптимальный размер.
Настройки дампа памяти находятся в расширенных свойствах системы, в разделе Загрузка и восстановление (Startup and Recovery). Здесь можно один из четырех типов дампа либо совсем отключить его создание.
Даже зная настройки дампа и объем физической памяти, не получится точно сказать, какого размера файл подкачки создаст система. Поэтому я решил немного поэкспериментировать, для чего взял в качестве подопытных 2 системы — клиентскую Windows 8.1 (x64) и серверную Windows Server 2012 R2 и проверил, как размер файла подкачки зависит от объема физической памяти и настроек дампа. Вот что получилось:
Windows 8.1 4Гб ОЗУ |
Windows 8.1 8Гб ОЗУ |
Windows Server 2012 R2 4Гб ОЗУ |
Windows Server 2012 R2 8Гб ОЗУ |
|
Полный дамп | 4352 Мб | 8704 Мб | 4352 Мб | 8704 Мб |
Дамп ядра | 4096 Мб | 8192 Мб | 4096 Мб | 8192 Мб |
Автоматический дамп | 704 Мб | 1280 Мб | 1408 Мб | 1920 Мб |
Малый дамп | 320 Мб | 512 Мб | 1408 Мб | 1920 Мб |
Нет дампа | 320 Мб | 512 Мб | 1408 Мб | 1920 Мб |
Как видите, размер файла напрямую зависит не только от объема ОЗУ и настроек дампа, но и от типа операционной системы. Кроме того, отключение дампа не означает полное отсутствие файла подкачки.
Также стоит напомнить, что это начальные значения. При нехватке виртуальной в процессе работы памяти система может увеличивать файл подкачки вплоть до максимального значения, которое при автоматической настройке составляет 3 объема физической памяти.
Определение необходимого размера файла подкачки
Хотя размером файла подкачки и можно управлять через настройки дампа памяти, однако это не самый прямой способ. Гораздо правильней настроить размер файла вручную. Остается только выяснить, какой размер можно считать достаточным.
Однозначного ответа на этот вопрос нет. Единственный способ более-менее точно установить размер файла подкачки — это собрать в данной конкретной системе данные по потреблению памяти и использованию файла подкачки, выяснить, какой максимальный объем памяти может быть занят службамиприложениями и насколько реально используется файл подкачки. На основании полученных данных и следует выбирать размер файла.
Оперативно оценить текущее потребление виртуальной памяти можно в Task manager, в разделе Performance (производительность). В поле Commited показано отношение используемой виртуальной памяти к ее общему количеству. В моем примере на компьютере установлено 64Гб оперативной памяти и такого же объема файл подкачки. Текущий объем виртуальной памяти составляет 128Гб, занято 65Гб. Из них 62,4Гб приходятся на оперативную память и 2,6Гб на файл подкачки.
Также для сбора информации можно воспользоваться счетчиками производительности. Счетчики предоставляют больше информации, а также позволяют собрать статистику за определенное время, что позволит более точно определить потребности системы в виртуальной памяти. Нам потребуются следующие счетчики производительности:
Memory, Commited Bytes — этот счетчик показывает, какое количество байт в виртуальной памяти занято текущими процессами. Когда значение Commited Bytes превышает объем физической памяти, система начинает активно использовать файл подкачки;
Memory, Available Bytes — объем свободной физической памяти на компьютере. Этот параметр показывает загруженность оперативной памяти, а чем меньше физической памяти остается, тем активнее система использует файл подкачки.
Memory, Commit Limit — значение, равное сумме объема оперативной памяти и текущего размера файла подкачки. По другому — максимальное количество виртуальной памяти, которое может быть выделено всем процессам без увеличения размера файла подкачки.
Memory, %Commited Bytes In Use — показывает процент использования виртуальной памяти. Представляет из себя отношение Commited Bytes Commit Limit.
Paging File, %Usage — процент использования файла подкачки, текущее значение.
Paging File, %Usage Peak — процент использования файла подкачки, пиковое значение.
Для более глубокого анализа потребления памяти можно дополнительно использовать такие счетчики:
Memory, Page Faultsec — количество страничных ошибок (прерываний) в секунду при обращении к страницам памяти. Напомню, что страничное прерывание возникает при обращении к странице памяти, которая была выгружена на диск.
Memory, Pagessec — показывает, сколько страниц в секунду было прочитанозаписано в рамках страничного прерывания. Проще говоря, этот счетчик показывает интенсивность обмена данными между оперативной памятью и файлом подкачки. Представляет из себя сумму счетчиков Pages Inputsec и Pages Outpitsec.
Process, Working Set — показывает текущее использование физической памяти активными процессами. Значение Total выдает суммарный объем по всем процессам, но можно вывести данные отдельно и по каждому конкретному процессу. Этот счетчик не имеет прямого отношения к файлу подкачки, но может помочь при диагностике проблем с производительностью.
Как видно на примере, 64-гигабайтный файл подкачки реально используется всего на 2-3%. То есть для нормальной работы с избытком хватит файла подкачки размером 4Гб. И это при том, что сервер очень прилично нагружен, для менее загруженного компьютера цифры будут еще меньше.
Отдельно стоит упомянуть о выборе размера файла подкачки для компьютеров с ролью Hyper-V. Дело в том, что в силу особенностей архитектуры гипервизор не использует файл подкачки для виртуальных машин даже в случае нехватки физической памяти. На серверах Hyper-V файл подкачки нужен исключительно для целей хостовой системы, в которой используется лишь небольшая часть ОЗУ (обычно не более 2-4ГБ). Поэтому создавать файл подкачки, исходя из общего объема физической памяти в данном случае абсолютно бессмысленно.
Настройка
Определив необходимый размер, переходим непосредственно о настройке. Для изменения размера файла подкачки открываем свойства виртуальной памяти и отключаем автоматический выбор размера. Затем в поле «Drive» выбираем логический диск, на котором будет располагаться файл, выбираем опцию «Custom size», указываем начальный и максимальный размер файла подкачки и жмем «Set». Для того, чтобы изменения вступили в силу, после настройки может потребоваться перезагрузка системы.
Для файла подкачки существуют некоторые ограничения:
• Максимальный размер файла может быть не более 16ТБ для 64-битной и не более 4ГБ для 32-битной системы;
• Можно создавать до 16 файлов подкачки, но каждый должен быть расположен на отдельном томе (логическом диске);
• Для возможности создания аварийного дампа памяти необходимо, чтобы файл подкачки (хотя бы один) находился на системном диске.
Для автоматизации процесса настройки можно использовать вот такой PowerShell скрипт (подставив свои значения):
# Disable automatic management for pagefile
$ComputerSystem = Get-WmiObject -Class Win32_ComputerSystem -EnableAllPrivileges
if ($ComputerSystem.AutomaticManagedPagefile) {
$ComputerSystem.AutomaticManagedPagefile = $false
$ComputerSystem.Put()
}
# Set manual size for pagefile
$PageFile = Get-WmiObject -Class Win32_PageFileSetting -EnableAllPrivileges
$PageFile.InitialSize = 4096
$PageFile.MaximumSize = 8192
$PageFile.Put()
Заключение
В заключение некоторые практические советы, которые могут помочь в настройке.
• При ручной настройке необходимо указать начальный и максимальный размер файла. В этом случае система создает файл начального размера, при необходимости увеличивая его до тех пор, пока он не достигнет максимального. При увеличении размера возможна фрагментация файла подкачки, что скажется на его быстродействии. Для борьбы с фрагментацией можно изначально указать начальный и максимальный размер одинаковыми. Тогда система сразу выделит под файл все необходимое место, а статический размер файла исключит возможную фрагментацию в дальнейшем.
• Для увеличения производительности системы файл подкачки можно перенести на другой раздел. Уточню, что переносить файл стоит только на раздел, находящийся на другом физическом диске. Размещение файла подкачки на дополнительном раздел одного и того же диска не приведет к повышению быстродействия. На практике имеет смысл перенос файла подкачки на отдельный SSD-диск, это может дать заметный прирост производительности.
• Еще один теоретический 🙂 способ повысить скорость работы с файлом подкачки — разместить его на отдельном, специально выделенном только под него разделе, для которого установить размер кластера 64Кб (вместо 4Кб по умолчанию). При работе с большими файлами (такими, как файл подкачки) большой размер кластера может повысить производительность файловой системы. Чем больше размер кластера, тем большими блоками читаютсяпишутся данные, соответственно для одинакового объема данных при размере кластера 64Кб потребуется в 16 раз меньше операций чтениязаписи, чем для 4Кб.
• Кое где встречаются советы полностью отключить файл подкачки. Действительно, в отдельных случаях это может дать некоторый прирост производительности, хотя лично я не вижу в этом большой пользы. Как можно убедиться с помощью счетчиков производительности, при наличии свободной физической памяти ОС и так использует файл подкачки по минимуму, поэтому прирост будет незначительный. Если же при отключенном файле подкачки в процессе работы закончится физическая память, то приложение, потребляющее память, будет остановлено, что чревато сбоем в работе и потерей данных. Кроме того, при отсутствии файла подкачки Windows не сможет сохранить дамп памяти в случае сбоя.
• И последнее. Манипуляции с файлом подкачки не особо сильно влияют на производительность системы в целом. Повторюсь, при достаточном количестве физической памяти файл подкачки используется по минимуму. Если же в системе постоянно не хватает памяти и она активно использует файл подкачки, то в первую очередь стоит подумать о расширении физической памяти.
Вики IT-KB
Пошаговые руководства, шпаргалки, полезные ссылки.
Инструменты пользователя
Инструменты сайта
Боковая панель
Настройка файла подкачки Windows на сервере SQL Server
К настройке файла подкачки Windows нужно подходить индивидуально в каждом отдельном случае. Общие рекомендации по этому поводу можно найти в статье KB2860880 — Определение размера файла подкачки для 64-разрядных версий Windows. Так как на серверах с СУБД SQL Server зачастую используется большой объём оперативной памяти, может потребоваться настройка ограничения размера файла подкачки. Это связано с тем, что автоматически рассчитываемый ОС Windows размер файла даже при полном отсутствии нагрузки на систему на только что установленной системе может оказаться крайне нескромным.
Вызовем апплет управления свойствами системы sysdm.cpl. В открывшейся форме переходим на закладку управления расширенными настройками Advanced и в блоке Performance нажимаем кнопку Settings. В дополнительно открывшейся форме переходим на вкладку Advanced и в разделе Virtual memory используем кнопку Change, чтобы изменить параметры файла подкачки.
Отключим используемое по умолчанию автоматическое определение размера файла подкачки, укажем первичный (Initial size) и максимально допустимый (Maximum size) размеры файла через опцию Custom size (например, от 2GB, но не больше 4GB) и нажмём Set, затем OK.
Устанавливая файл подкачки ограниченного размера следуют выполнять дальнейший контроль процента его использования, чтобы не получилось так, что системе под продуктивными нагрузками на самом деле требуется больший объём подкачки, чем установлен. Следить за этим показателем можно с помощью консоли Performance Monitor и счётчиков производительности:
После добавления визуализации указанных счётчиков в нашем примере становится видно, что текущее использование файла подкачки на нулевом уровне.
Так как в системах Windows Server 2012 и выше на размер файла подкачки влияют требования, выставляемые к аварийному дампу системы (memory.dmp), мы можем сократить эти требования за счёт изменения параметров создания аварийного дампа. Для этого в том же апплете управления свойствами системы sysdm.cpl на закладке управления расширенными настройками Advanced в блоке Startup and Recovery нажимаем кнопку Settings. В открывшейся форме в разделе System failure вместо Automatic memory dump выбираем Small memory dump
Дополнительные источники информации:
Проверено на следующих конфигурациях:
Автор первичной редакции:
Алексей Максимов
Время публикации: 10.02.2019 20:51
Источник
Увеличение файла подкачки или зачем нужна виртуальная память?
Наверняка каждый пользователь сталкивался с ситуацией, когда компьютеру для нормальной работы не хватает оперативной памяти, вследствие чего операционная система обращается за помощью к так называемой виртуальной памяти, чтобы восполнить данную нехватку. О том, что такое виртуальная память, и как ее увеличить и читайте в данной статье.
0. Виртуальная память, что это такое?
Под понятием виртуальная память следует понимать сочетание памяти временного хранилища и оперативного запоминающего устройства (ОЗУ) на жестком диске (винчестере).
В том случае, когда все работающие на компьютере программы полностью занимают ОЗУ, оперативная память захватывает часть пространства на винчестере и создает там, так называемый, файл подкачки. Сразу же после перемещения информационных данных в этот файл, оперативная память освобождается. Этого достаточно для выполнения операций. Программы не «видят» разницы между виртуальной и оперативной памятью, единственным отличием является то, что настоящая оперативная память может обеспечивать значительно меньшее время доступа, нежели виртуальная.
1. Влияние ОЗУ на скорость работы программ
Скорость работы всех программ во многом зависит от объема оперативной памяти, проще говоря, чем больше объем ОЗУ, установленного в компьютере, тем быстрее эти программы работают. Если вследствие нехватки оперативной памяти работа компьютера замедляется, то ее следует восполнить путем увеличения размера виртуальной памяти на винчестере. Однако здесь следует учитывать, что данные с ОЗУ считываются быстрее, нежели с жесткого диска. Потому предпочтительнее будет добавить ОЗУ.
2. Увеличение виртуальной памяти
Если всплывает окно с сообщением об ошибках, вызванных недостаточным размером виртуальной памяти, следует выполнить одно из двух действий, либо увеличить размер файла подкачки, либо добавить ОЗУ.
Как правило, операционная система автоматически меняет размер файла подкачки. Однако если размер этого файла все же недостаточный для правильной работы компьютера, то его можно увеличить вручную.
Чтобы это осуществить, необходимо выполнить следующие действия:
В Windows XP: Необходимо правой кнопкой мышки щелкнуть на значок «Мой компьютер» после чего перейти по пункту «Свойства».
В Windows Vista и старше: Перейдем в «Панель управления» — «Система и безопасность» — «Система» — «Дополнительные параметры системы»
Откроется окно «Свойства системы». Перейдем на вкладку «Дополнительно» и нажмем «Параметры» быстродействия.
Откроется окошко, в котором нужно выбрать вкладку «Дополнительно», затем нажать «Изменить» в группе «Виртуальная память».
Снимем флаг «Автоматически выбирать объем файла подкачки» и, выбрав диск, с которого будет осуществляться подкачка файла, устанавливаем значения исходного и максимального размеров виртуальной памяти. Необходимо в исходный размер записать рекомендуемое число, а в максимальном размере установить большое значение, например число 7000. После этого нажать на кнопку «Задать».
После этого следует принять все изменения, нажав в каждом окне кнопку «Ок» и перезагрузить компьютер.
Смотрите также:
Иногда в Windows 7 нужно изменить расширение вручную, например, превратить файл “txt” в “bat”. Первое, что приходит на ум, — переименовать (F2). Но оказывается, что расширение «.bat» ты вроде бы…
По умолчанию в гипервизоре Hyper-V в Windows Server 2008 для отдельной виртуальной машины число логических процессоров можно устанавливать в диапазоне от 1 до 4. С помощью нехитрых манипуляций можно обойти…
Переустановка операционной системы или смена компьютерного устройства не означает конец работы с установленными гостевыми ОС в программе VirtualBox. Правда, исключением может быть случай, когда файлы жёстких дисков виртуальных машин находятся на…
Источник
Размер файла подкачки windows server 2008 r2
Вопрос
Назначенный файл подкачки не используется ОС и не виден в диспетчере задач, однако виден в дополнительный свойствах системы и на диске на который он назначен. Сервер терминалов 16 Юзверей + Одмин 16- гигов физической памяти не хватает для одновременной работы всех в 1С 8.2
Помогите пожалуйста как можно сделать что бы файл подкачки использовался системой!
Ответы
Предложу другой вариант, мой коллега — Mikhail_Komarov написал хорошую статью, которую Вы могли бы применить в своей ситуации.
Правильно понимаю, что роль RD Session Host, SQL Server и 1С установлены на одном сервере?Параметр Maximum server memory в SQL Server задействует всю физическую память или только часть? Похожая проблема разбирается здесь.
Также еще можно задать ваш вопрос на специализированном форуме по 1С.
- Изменено osr_ MVP, Moderator 22 января 2016 г. 12:59
- Предложено в качестве ответа Alexander Rusinov Moderator 22 января 2016 г. 21:47
- Помечено в качестве ответа Petko Krushev Microsoft contingent staff, Moderator 1 февраля 2016 г. 12:29
Вы не ответили на мой вопрос про значение параметра Maximum Server Memory
Чтобы не раздражать глупыми вопросами, давайте поступим так. На Форумах TechNet я нашел два результативных обсуждения, относящихся к повышению производительности конфигураций сервера 1С, похожего на ваш. Ознакомьтесь с обсуждениями и укажите, какие настройки вы уже выполняли, и они не привели к повышению производительности.
Если судить по картинке, Вашему серверу хватает памяти, в строке Free еще 2625MB, был бы 0 — другое дело.
Где отклик от дисковой подсистемы?
Все ответы
16- гигов физической памяти не хватает для одновременной работы всех в 1С 8.2
Файл подкачки не добавит в систему физической памяти, если ее не хватает для запущенных приложений, у него другое назначение.
Расскажите подробно, по каким признакам вы определяете, что файл подкачки не используется.
Сервер начинает тормозить при достижении 85-90% загрузки физической памяти.
Вы наверное не сталкивались с работой SQL-server и особенностью его работы, база данных 14ГБ и ему в принципе не хватит 16 ГБ для работы одного пользователя в течении одной рабочей недели (он забьет всю память своими процессами).
Расскажите подробно, по каким признакам вы определяете, что файл подкачки не используется.
Правильно понимаю, что роль RD Session Host, SQL Server и 1С установлены на одном сервере?Параметр Maximum server memory в SQL Server задействует всю физическую память или только часть? Похожая проблема разбирается здесь.
Также еще можно задать ваш вопрос на специализированном форуме по 1С.
- Изменено osr_ MVP, Moderator 22 января 2016 г. 12:59
- Предложено в качестве ответа Alexander Rusinov Moderator 22 января 2016 г. 21:47
- Помечено в качестве ответа Petko Krushev Microsoft contingent staff, Moderator 1 февраля 2016 г. 12:29
Правильно понимаю, что роль RD Session Host, SQL Server и 1С установлены на одном сервере?Параметр Maximum server memory в SQL Server задействует всю физическую память или только часть? Похожая проблема разбирается здесь.
Также еще можно задать ваш вопрос на специализированном форуме по 1С.
Я не задаю вопросы на форумах если на нем есть ответы.
sqlservr.exe — 240 Мб
1cv8.exe каждый от 130 до 280 Мб
Все остальное рабочие процессы пользователей рабочих столов, включая Exel, Word и тд
Все параметры проверены трижды — это было сделано в первую очередь, перед тем как искать ответы в интернете!
Источник