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

Публикация № 237919

Администрирование - Системное

AutoIT

30
Для большинства пользователей операционная система – это «черный ящик», и что происходит внутри него – это таинство. Но иногда хочется «пнуть» этот ящик, что бы он работал так, как надо… Конечно, принудительная очистка 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:\UTIL\RAMMap\RAMMap.exe

;----------------------------------------------------------------------------

; RamMap -- работает только для Windows Vista и выше ...

;----------------------------------------------------------------------------

Local $hWnd                         ; идентификатор окна программы

Local $ret                               ; идентификатор программы

; Если программа еще не запущена - запускаем RamMAP

If Not WinExists("[CLASS:RamMapClass]") Then

            $ret = ShellExecute('C:\UTIL\RAMMap\RAMMap.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

Скачать файлы

Наименование Файл Версия Размер
RunRamMap.zip
.zip 824,03Kb
28.09.16
73
.zip 824,03Kb 73 Скачать

См. также

Специальные предложения

Комментарии
Избранное Подписка Сортировка: Древо
1. Alex1Cnic 125 25.11.13 08:19 Сейчас в теме
Интересно, а как бы такую штуку rammap для win XP сделать или существуует подобная утилита??
2. LexSeIch 198 25.11.13 10:43 Сейчас в теме
К сожалению RamMap, только начиная с Vista - в XP видимо - другая модель управления памятью.
3. AlexBugs 27.11.13 08:23 Сейчас в теме
А для сервера с MS W2008R2 64 bit эта утилитка подойдет? кайф от ее использования будет?
5. LexSeIch 198 28.11.13 04:06 Сейчас в теме
(3) AlexBugs,
Да, подойдет - скриншоты в примере, как раз сняты в такой системе. RamMap - очень полезная утилита, подробнее с ней можно ознакомиться в книге Руссиновича, Маргозиса: "Утилиты Sysinternals. Справочник администратора". А на счет кайфа - все зависит зависит от ПО, которое у Вас запущено. По крайней мере хуже не будет.
19. gabriel20 31.08.16 07:21 Сейчас в теме
(3) AlexBugs, на сервере 2012R2 работает на ура
4. DAnry 6 27.11.13 19:26 Сейчас в теме
Спасибо. Интересная статья.
6. dkonakov 6 21.04.14 10:54 Сейчас в теме
Очень полезная статья! Решила многие мои проблемы на сервере терминалов.
7. LexSeIch 198 21.04.14 18:27 Сейчас в теме
(6) dkonakov,
Если можно, немного подробнее о проблемах. В моей практике, например, наблюдалось некоторое замедление работы программ, после запуска некоторых приложений в течении дня (поэтому утром, перед началом рабочего, дня принудительно очищаю память). А какие проблемы были у Вас?
16. dkonakov 6 17.01.16 16:15 Сейчас в теме
(7) у меня проблемы начинались, когда свободная память приходила к нулю. А на текущем этапе, когда перешли на управляемые формы, приходится делать раза 2-3 в день, 32 Гигобайта на 2008 сервере не хватает.
17. LexSeIch 198 20.01.16 06:09 Сейчас в теме
(16) dkonakov,
Не пробовали, при недостатке памяти, утилитой RamMap проверить на каких процессах, файлах "уходит" память.
8. Divisi0n_by_zer0 11.05.15 15:16 Сейчас в теме
супер скрипт! на сервере 16 гигов памяти, после ночного бэкапа вся standby была загажена кусками файловых бэкапов... а теперь всё хорошо )
10. mas76 13.07.15 17:24 Сейчас в теме
скомпилировал скрипт, но не работает сброс стенбая и закрытие программы
11. mas76 13.07.15 17:46 Сейчас в теме
все отбой все получилось, спасибо
32. user973548 11.05.18 11:53 Сейчас в теме
(11) У меня не получилось, подскажите как сделали?
12. Vic_V 11.08.15 07:59 Сейчас в теме
Статья полезная. Ручное использование утилиты помогает., но полностью Standby память не очищается, из 1600 осталось около 700 К занято.
Сам скомпилировать скрипт не могу, а специально зарабатывать $m не буду.
13. capitan 1167 11.08.15 11:37 Сейчас в теме
На самом деле, существует определенное количество специализированных менеджеров памяти - пример Cacheman.
По моим ощущениям на порядок возрастает дисковая активность.
И к тому же, у меня есть подозрение - windows сам разруливает как standby превратить в free.
В любом случае автору респект за интересную статью.
14. bogdan_sukonnov 58 15.10.15 18:05 Сейчас в теме
В заголовке ошибка - утилита называется RAMMAP. А вообще, только она и помогла, тоже сервер через некоторое время выедал free память и начинал тормозить. Перезагрузка, конечно помогала, и во многих отношениях она лучше. Но если перезагрузить никак, а память освободить нужно - эта утилита просто спасение!
LexSeIch; +1 Ответить
15. KSV53 11.12.15 21:45 Сейчас в теме
каждый раз не поперезагружаешь, а выкидывать каждый раз пользователей не вариант
18. nick_e 2 12.05.16 09:43 Сейчас в теме
Полезная статья. Хотел запускать RAMMap.exe без указания пути, не работает при запуске из планировщика задач.
Чтобы каждый раз скрипт не перекомпилировать когда папку хранения программы меняешь, сделал так:
$ret = ShellExecute(@ScriptDir &'\RAMMap.exe')
gabriel20; LexSeIch; +2 Ответить
20. almot77 07.10.16 17:50 Сейчас в теме
Есть утилита CLI называется EmptyStandbyList.exe
soci0pat; Nikita890; pridecom; SashaSashaSashka; +4 Ответить
24. SashaSashaSashka 30.06.17 11:47 Сейчас в теме
(20) Действительно. Самый простой вариант. Качаем прямо по первой Гугл-ссылке, кидаем в планировщик и всё!
pridecom; +1 Ответить
21. cj_nik 27.12.16 17:50 Сейчас в теме
Написали для этого дела скрипт.
Код на C#, обертка на PowerShell: https://gallery.technet.microsoft.com/c-PowerShell-wrapper-6465e028
22. LexSeIch 198 28.12.16 09:27 Сейчас в теме
(21) Отлично. Больше решений - меньше проблем у пользователя...
23. Djagernaut 45 01.04.17 15:12 Сейчас в теме
Смею сделать замечание, что подобный механизм не работает в связке с Hyper-V, даже после освобождения всей доступной для очистки памяти гипервизор считает ее занятой, и помогает только REBOOT.
LexSeIch; +1 Ответить
25. Nikita890 05.09.17 07:01 Сейчас в теме
Большое спасибо,то ли после настройки бэкапа, то ли оттого, что увеличилось количество пользователей 1с стала накапливаться Standby память на сервере, и свободной памяти стало не хватать. Пока что просто очистил standby неглядя, потом буду смотреть детально, откуда что берется, как я понимаю программа позволяет это сделать.
26. LexSeIch 198 07.09.17 10:32 Сейчас в теме
Да, программа просто отличная, и можно посмотреть: куда уходят ресурсы. Я ее применяю не только на сервере но и на рабочих станциях под Windows 7 (там то же память после некоторых задач не освобождается). Я заметил, что такое иногда происходит даже при операциях простого копирования очень больших файлов (десятки Гб). На сайте самой программы (которая, кстати иногда обновляется последнее обновление 02.02.2016 г.) есть еще очень много полезных утилит, которые заслуживают внимания для мониторинга автозагрузки, запущенных задач и т.д.. Утилиты документированы и выпущена книга на русском языке, описывающая пакет утилит "Утилиты Sysinternals. Справочник администратора".
27. Nikita890 21.09.17 12:34 Сейчас в теме
Вот бы кто скриптом поделился, сам не справился с созданием(
29. Nikita890 06.10.17 06:32 Сейчас в теме
Скачал EmptyStandbyList.exe добавил в планировщик заданий от имени администратора (важно!) и проблема решена.
30. lustin 394 01.12.17 12:43 Сейчас в теме
для тех кто придет из интернета сюда оставлю следующее

в 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)
Moskovkin; MariusUrsus; Nikita890; +3 Ответить
31. user891709 10.01.18 08:40 Сейчас в теме
а с какой периодичностью стоит запускать данный скрипт?
Оставьте свое сообщение