Принудительная очистка Standby — оперативной памяти по расписанию посредством утилиты RamMap и скрипта Autoit.







Для большинства пользователей операционная система – это «черный ящик», и что происходит внутри него – это таинство. Но иногда хочется «пнуть» этот ящик, что бы он работал так, как надо… Конечно, принудительная очистка standby памяти напоминает «танец с бубном» (вроде система должна делать это сама), но в некоторых случаях она помогает…

 «Памяти мало не бывает» —  Народное правило апгрейда компьютера.

Внимание!!! Все описанное ниже относится к Windows Vista и выше…

Каждый, кто хоть раз заглядывал (кто из любопытства, кто по долгу службы)  в «Монитор ресурсов» на закладку «Память» видел подобную картинку:

Рис 1.

Причем, через некоторое время, она существенно меняется (в зависимости от используемого ПО и настройки системы):

Рис. 2

Мы видим, что память из списка «Ожидание» (Standby) – растет, свободная память – уменьшается…

В данном случае свободной памяти почти не осталось:

Рис. 3

А в Standby памяти находятся большие файлы архивов вечернего бэкапа:

Рис. 4

И самое главное, есть 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 памяти.

 Рис. 5

Результат выполнения очистки (красым отмечена свободная память):

Рис. 6

 И в мониторе ресурсов свободной памяти значительно прибавилось:

 Рис. 7

Эта утилита, написанная легендарным Марком Руссиновичем в соавторстве с Дэвидом Саломоном, она прекрасно справляется с данной задачей. Ее авторы – признанные специалисты по 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 как оно есть 

Мир Вашему дому!

30 Comments

  1. Alex1Cnic

    Интересно, а как бы такую штуку rammap для win XP сделать или существуует подобная утилита??

    Reply
  2. LexSeIch

    К сожалению RamMap, только начиная с Vista — в XP видимо — другая модель управления памятью.

    Reply
  3. AlexBugs

    А для сервера с MS W2008R2 64 bit эта утилитка подойдет? кайф от ее использования будет?

    Reply
  4. DAnry

    Спасибо. Интересная статья.

    Reply
  5. LexSeIch

    (3) AlexBugs,

    Да, подойдет — скриншоты в примере, как раз сняты в такой системе. RamMap — очень полезная утилита, подробнее с ней можно ознакомиться в книге Руссиновича, Маргозиса: «Утилиты Sysinternals. Справочник администратора». А на счет кайфа — все зависит зависит от ПО, которое у Вас запущено. По крайней мере хуже не будет.

    Reply
  6. dkonakov

    Очень полезная статья! Решила многие мои проблемы на сервере терминалов.

    Reply
  7. LexSeIch

    (6) dkonakov,

    Если можно, немного подробнее о проблемах. В моей практике, например, наблюдалось некоторое замедление работы программ, после запуска некоторых приложений в течении дня (поэтому утром, перед началом рабочего, дня принудительно очищаю память). А какие проблемы были у Вас?

    Reply
  8. Divisi0n_by_zer0

    супер скрипт! на сервере 16 гигов памяти, после ночного бэкапа вся standby была загажена кусками файловых бэкапов… а теперь всё хорошо )

    Reply
  9. mas76

    скомпилировал скрипт, но не работает сброс стенбая и закрытие программы

    Reply
  10. mas76

    все отбой все получилось, спасибо

    Reply
  11. Vic_V

    Статья полезная. Ручное использование утилиты помогает., но полностью Standby память не очищается, из 1600 осталось около 700 К занято.

    Сам скомпилировать скрипт не могу, а специально зарабатывать $m не буду.

    Reply
  12. capitan

    На самом деле, существует определенное количество специализированных менеджеров памяти — пример Cacheman.

    По моим ощущениям на порядок возрастает дисковая активность.

    И к тому же, у меня есть подозрение — windows сам разруливает как standby превратить в free.

    В любом случае автору респект за интересную статью.

    Reply
  13. bogdan_sukonnov

    В заголовке ошибка — утилита называется RAMMAP. А вообще, только она и помогла, тоже сервер через некоторое время выедал free память и начинал тормозить. Перезагрузка, конечно помогала, и во многих отношениях она лучше. Но если перезагрузить никак, а память освободить нужно — эта утилита просто спасение!

    Reply
  14. KSV53

    каждый раз не поперезагружаешь, а выкидывать каждый раз пользователей не вариант

    Reply
  15. dkonakov

    (7) у меня проблемы начинались, когда свободная память приходила к нулю. А на текущем этапе, когда перешли на управляемые формы, приходится делать раза 2-3 в день, 32 Гигобайта на 2008 сервере не хватает.

    Reply
  16. LexSeIch

    (16) dkonakov,

    Не пробовали, при недостатке памяти, утилитой RamMap проверить на каких процессах, файлах «уходит» память.

    Reply
  17. nick_e

    Полезная статья. Хотел запускать RAMMap.exe без указания пути, не работает при запуске из планировщика задач.

    Чтобы каждый раз скрипт не перекомпилировать когда папку хранения программы меняешь, сделал так:

    $ret = ShellExecute(@ScriptDir &’RAMMap.exe’)
    
    Reply
  18. gabriel20

    (3) AlexBugs, на сервере 2012R2 работает на ура

    Reply
  19. almot77

    Есть утилита CLI называется EmptyStandbyList.exe

    Reply
  20. cj_nik

    Написали для этого дела скрипт.

    Код на C#, обертка на PowerShell: https://gallery.technet.microsoft.com/c-PowerShell-wrapper-6465e028

    Reply
  21. LexSeIch

    (21) Отлично. Больше решений — меньше проблем у пользователя…

    Reply
  22. Djagernaut

    Смею сделать замечание, что подобный механизм не работает в связке с Hyper-V, даже после освобождения всей доступной для очистки памяти гипервизор считает ее занятой, и помогает только REBOOT.

    Reply
  23. SashaSashaSashka

    (20) Действительно. Самый простой вариант. Качаем прямо по первой Гугл-ссылке, кидаем в планировщик и всё!

    Reply
  24. Nikita890

    Большое спасибо,то ли после настройки бэкапа, то ли оттого, что увеличилось количество пользователей 1с стала накапливаться Standby память на сервере, и свободной памяти стало не хватать. Пока что просто очистил standby неглядя, потом буду смотреть детально, откуда что берется, как я понимаю программа позволяет это сделать.

    Reply
  25. LexSeIch

    Да, программа просто отличная, и можно посмотреть: куда уходят ресурсы. Я ее применяю не только на сервере но и на рабочих станциях под Windows 7 (там то же память после некоторых задач не освобождается). Я заметил, что такое иногда происходит даже при операциях простого копирования очень больших файлов (десятки Гб). На сайте самой программы (которая, кстати иногда обновляется последнее обновление 02.02.2016 г.) есть еще очень много полезных утилит, которые заслуживают внимания для мониторинга автозагрузки, запущенных задач и т.д.. Утилиты документированы и выпущена книга на русском языке, описывающая пакет утилит «Утилиты Sysinternals. Справочник администратора».

    Reply
  26. Nikita890

    Вот бы кто скриптом поделился, сам не справился с созданием(

    Reply
  27. Nikita890

    Скачал EmptyStandbyList.exe добавил в планировщик заданий от имени администратора (важно!) и проблема решена.

    Reply
  28. lustin

    для тех кто придет из интернета сюда оставлю следующее

    в 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)

    Reply
  29. user891709

    а с какой периодичностью стоит запускать данный скрипт?

    Reply
  30. user973548

    (11) У меня не получилось, подскажите как сделали?

    Reply

Leave a Comment

Ваш адрес email не будет опубликован. Обязательные поля помечены *