«Памяти мало не бывает» — Народное правило апгрейда компьютера.
Внимание!!! Все описанное ниже относится к Windows Vista и выше…
Каждый, кто хоть раз заглядывал (кто из любопытства, кто по долгу службы) в «Монитор ресурсов» на закладку «Память» видел подобную картинку:
Причем, через некоторое время, она существенно меняется (в зависимости от используемого ПО и настройки системы):
Мы видим, что память из списка «Ожидание» (Standby) – растет, свободная память – уменьшается…
В данном случае свободной памяти почти не осталось:
А в Standby памяти находятся большие файлы архивов вечернего бэкапа:
И самое главное, есть 100% уверенность, что нахождение их в Standby памяти не целесообразно – бэкап уже закончился.
Теоретически, Standby память содержит кэшированные данные, которые возможно, когда-нибудь будут использоваться в дальнейшем… При этом, когда системе потребуется дополнительные ресурсы, системный менеджер памяти может освободить из списка Standby необходимую память.
На практике, иногда случаются ситуации, подобные этой :
«В тестовом режиме гоняем сервер (8x2CPU AMD 64G RAM) баз данных на MS W2008R2 KR c MSSQL 2008. Под SQL выделено 50 G. Почти месяц машина отработала нормально, но последнии несколько дней вся свободная память из free перешла в Standby и производительность снизилась … причем система говорит что используется всего 52-53 G. После рестарта система съедает полженные 52-53 Gи начинает привращение Free to Standby. По завершению сего процесса снова начинаются «дикие тормаза».
p.s. сервер mssql+1cv81 4 базы: 2 торговли не типовых 65G каждая, 1 ЗУП 1,5G 1 бухгалтерия 14G Подскажите как standby превратить в free «
Конечно не факт, что «тормоза» в данном конкретном случае возникли только по этой причине, но как говорят: «осадок остался».
Я так же замечал, что при работе некоторых приложений (особенно написанных для предыдущих ОС) количество свободной памяти иногда резко уменьшается и субъективно, система начинает «подтормаживать» а некоторые приложения, например 1С 7.7 Предприятие даже «вываливались» без всяких сообщений. Чаще всего в подобных случаях спасает перезагрузка системы.
Так как Standby память – страницы физической памяти, которые активно не используются, и могут быть при необходимости выделены менеджером памяти другим задачам, значит, не будет ничего плохого, если мы освободим их без участия системы, но, конечно, корректно.
Есть прекрасная утилита фирмы Sysinternals (www.sysinternals.com) RamMap. Одна из опций данной программы, как раз, и отвечает за очистку Standby памяти.
Результат выполнения очистки (красым отмечена свободная память):
И в мониторе ресурсов свободной памяти значительно прибавилось:
Эта утилита, написанная легендарным Марком Руссиновичем в соавторстве с Дэвидом Саломоном, она прекрасно справляется с данной задачей. Ее авторы – признанные специалисты по Windows-системам (это к корректности реализации). К слову, весь пакет программ – это «швейцарский нож» для каждого системного администратора.
Единственный недостаток, то, что выбор и запуск данной опции в программе происходит в интерактивном режиме. Автоматизировать нажатия кнопок и выбор меню нам поможет простой скрипт на AutoIT:
;—————————————————————————-
#RequireAdmin
#Region ;**** Directives created by AutoIt3Wrapper_GUI ****
#AutoIt3Wrapper_UseX64=y
#AutoIt3Wrapper_Res_Language=1049
#AutoIt3Wrapper_Res_requestedExecutionLevel=asInvoker
#EndRegion ;**** Directives created by AutoIt3Wrapper_GUI ****
;—————————————————————————-
; SAM — 20/11/2013
;—————————————————————————-
; RunRamMap — оболочка для запуска утилиты Sysinternals RamMap
; — после запуска программы выполняется очистка Standby памяти
; — после 10-15 секунд работы программа закрывается…
;
; Оригинальная утилита должна находиться в каталоге: C:UTILRAMMapRAMMap.exe
;—————————————————————————-
; RamMap — работает только для Windows Vista и выше …
;—————————————————————————-
Local $hWnd ; идентификатор окна программы
Local $ret ; идентификатор программы
; Если программа еще не запущена — запускаем RamMAP
If Not WinExists(«[CLASS:RamMapClass]») Then
$ret = ShellExecute(‘C:UTILRAMMapRAMMap.exe‘)
If @error Then
MsgBox(4096, ‘Сообщение’, ‘Ошибка запуска RamMap.exe.’, 30)
Exit 1
EndIf
EndIf
; Ожидаем появление окна программы RamMap
$hWnd = WinWait(«[CLASS:RamMapClass]», «», 10)
If Not $hWnd Then
MsgBox(4096, ‘Сообщение’, ‘Окно RamMap не найдено, завершаем работу’)
Exit 2
Else
WinActivate(«[CLASS:RamMapClass]», «») ; наше окно — активное
EndIf
; Выбираем пункт «Empty Standby List» в меню «Empty» программы
WinMenuSelectItem($hWnd, », ‘&Empty’, ‘Empty S&tandby List’)
; ждем выполнение очистки 5 сек… (ориентировочно…)
Sleep(5000)
; обновляем экран
Send(«{F5}»)
; Ждем 5 секунд, чтобы увидеть результат и выйти…
Sleep(5000)
; Закрываем программу.
WinClose($hWnd)
;—————————————————————————-
Скрипт компилируем в исполняемый файл. После чего, в Планировщике заданий можно создать системное задание по расписанию, которое, например, перед началом рабочего дня, очищает память, тем самым освобождая так необходимые пользователю ресурсы.
Еще раз повторюсь – эта утилита (RamMap) работает на Windows Vista и выше…
В архивном файле находится исходный текст скрипта и скомпилированные модули для запуска в 32 и 64 разрядных системах. Свежую версию утилиты RamMap лучше загрузить с сайта автора: http://live.sysinternals.com/rammap.exe
PS: Для тех, кто любит разбираться в деталях – ссылка на статью по организации управления памяти в Windows: Here be dragons: Управление памятью в Windows как оно есть
Мир Вашему дому!
Интересно, а как бы такую штуку rammap для win XP сделать или существуует подобная утилита??
К сожалению RamMap, только начиная с Vista — в XP видимо — другая модель управления памятью.
А для сервера с MS W2008R2 64 bit эта утилитка подойдет? кайф от ее использования будет?
Спасибо. Интересная статья.
(3) AlexBugs,
Да, подойдет — скриншоты в примере, как раз сняты в такой системе. RamMap — очень полезная утилита, подробнее с ней можно ознакомиться в книге Руссиновича, Маргозиса: «Утилиты Sysinternals. Справочник администратора». А на счет кайфа — все зависит зависит от ПО, которое у Вас запущено. По крайней мере хуже не будет.
Очень полезная статья! Решила многие мои проблемы на сервере терминалов.
(6) dkonakov,
Если можно, немного подробнее о проблемах. В моей практике, например, наблюдалось некоторое замедление работы программ, после запуска некоторых приложений в течении дня (поэтому утром, перед началом рабочего, дня принудительно очищаю память). А какие проблемы были у Вас?
супер скрипт! на сервере 16 гигов памяти, после ночного бэкапа вся standby была загажена кусками файловых бэкапов… а теперь всё хорошо )
скомпилировал скрипт, но не работает сброс стенбая и закрытие программы
все отбой все получилось, спасибо
Статья полезная. Ручное использование утилиты помогает., но полностью Standby память не очищается, из 1600 осталось около 700 К занято.
Сам скомпилировать скрипт не могу, а специально зарабатывать $m не буду.
На самом деле, существует определенное количество специализированных менеджеров памяти — пример Cacheman.
По моим ощущениям на порядок возрастает дисковая активность.
И к тому же, у меня есть подозрение — windows сам разруливает как standby превратить в free.
В любом случае автору респект за интересную статью.
В заголовке ошибка — утилита называется RAMMAP. А вообще, только она и помогла, тоже сервер через некоторое время выедал free память и начинал тормозить. Перезагрузка, конечно помогала, и во многих отношениях она лучше. Но если перезагрузить никак, а память освободить нужно — эта утилита просто спасение!
каждый раз не поперезагружаешь, а выкидывать каждый раз пользователей не вариант
(7) у меня проблемы начинались, когда свободная память приходила к нулю. А на текущем этапе, когда перешли на управляемые формы, приходится делать раза 2-3 в день, 32 Гигобайта на 2008 сервере не хватает.
(16) dkonakov,
Не пробовали, при недостатке памяти, утилитой RamMap проверить на каких процессах, файлах «уходит» память.
Полезная статья. Хотел запускать RAMMap.exe без указания пути, не работает при запуске из планировщика задач.
Чтобы каждый раз скрипт не перекомпилировать когда папку хранения программы меняешь, сделал так:
(3) AlexBugs, на сервере 2012R2 работает на ура
Есть утилита CLI называется EmptyStandbyList.exe
Написали для этого дела скрипт.
https://gallery.technet.microsoft.com/c-PowerShell-wrapper-6465e028
Код на C#, обертка на PowerShell:
(21) Отлично. Больше решений — меньше проблем у пользователя…
Смею сделать замечание, что подобный механизм не работает в связке с Hyper-V, даже после освобождения всей доступной для очистки памяти гипервизор считает ее занятой, и помогает только REBOOT.
(20) Действительно. Самый простой вариант. Качаем прямо по первой Гугл-ссылке, кидаем в планировщик и всё!
Большое спасибо,то ли после настройки бэкапа, то ли оттого, что увеличилось количество пользователей 1с стала накапливаться Standby память на сервере, и свободной памяти стало не хватать. Пока что просто очистил standby неглядя, потом буду смотреть детально, откуда что берется, как я понимаю программа позволяет это сделать.
Да, программа просто отличная, и можно посмотреть: куда уходят ресурсы. Я ее применяю не только на сервере но и на рабочих станциях под Windows 7 (там то же память после некоторых задач не освобождается). Я заметил, что такое иногда происходит даже при операциях простого копирования очень больших файлов (десятки Гб). На сайте самой программы (которая, кстати иногда обновляется последнее обновление 02.02.2016 г.) есть еще оченьмного полезных утилит , которые заслуживают внимания для мониторинга автозагрузки, запущенных задач и т.д.. Утилиты документированы и выпущена книга на русском языке, описывающая пакет утилит «Утилиты Sysinternals. Справочник администратора».
Вот бы кто скриптом поделился, сам не справился с созданием(
Скачал EmptyStandbyList.exe добавил в планировщик заданий от имени администратора (важно!) и проблема решена.
для тех кто придет из интернета сюда оставлю следующее
в 2011 году я заколебался периодически проверять GUI RamMap на 1С серваках и тыкать Empty мышкой
напомню что в 1С у нас проблема не с StandBy а с MappedFile
в 2011 году на форуме SysInternals автор wj32 опубликовал утилитуhttps://forum.sysinternals.com/rammap-empty-standby-list_topic27297_post132769.html#132769
на текущий момент автор wj32 опубликовал консольную утилиту у себя сна сайтеhttps://wj32.org/wp/software/empty-standby-list/
она и назначается на планировщик как верно заметил (29)
а с какой периодичностью стоит запускать данный скрипт?
(11) У меня не получилось, подскажите как сделали?