Регулярная перезагрузка Сервера 1С с чисткой кэша

Батник для перезагрузки агента сервера 1С и чистки серверного кэша и сеансовых данных.
Для регулярной перезагрузки вставляем в планировщик заданий Windows.

Текст батника взят из нескольких источников (уже не помню)

Текст нужно отредактировать для конкретного сервера (задать имя агента, папку установки 1с, папку кэша)

Текст батника можно составить программно на основе этого кода. В этой статье я не стал этого делать

Сначала прокомментируем текст батника:

— Начало батника  (.bat)

— Задаем Имя службы агента сервера 1С

set agent="1C:Enterprise 8.3 Server Agent" 

— Задаем файл лога

set logfile="\localhostlogLOG_restart.TXT"

— Останавливаем службу агента сервера 1С

:: Stop the server agent service 1C
echo %date% %time% "net stop Agent 1C" >>%logfile%
net stop %agent% >>%logfile%

— Ждем, пока служба остановится

:: pause
set timeout=60
echo %date% %time% "Begin pause" >>%logfile%
timeout /t %timeout% /nobreak >nul
echo %date% %time% "End Pause" >>%logfile%

— Снимаем процессы 1с, которые зависли

:: kill the process
echo %date% %time% "TASKKILL rphost.exe" >>%logfile%
TASKKILL /F /IM "rphost.exe">>%logfile%
echo %date% %time% "TASKKILL rmngr.exe" >>%logfile%
TASKKILL /F /IM "rmngr.exe">>%logfile%
echo %date% %time% "TASKKILL ragent.exe" >>%logfile%
TASKKILL /F /IM "ragent.exe">>%logfile%
echo %date% %time% "TASKKILL 1cv8.exe" >>%logfile%
TASKKILL /F /IM "1cv8.exe">>%logfile%
echo %date% %time% "TASKKILL 1cv8c.exe" >>%logfile%
TASKKILL /F /IM "1cv8c.exe">>%logfile%
echo %date% %time% "TASKKILL 1cv8t" >>%logfile%
TASKKILL /F /IM "1cv8t">>%logfile%
echo %date% %time% "TASKKILL 1cv8s.exe" >>%logfile%
TASKKILL /F /IM "1cv8s.exe">>%logfile%

— Небольшая пауза после снятия процессов

:: pause
set timeout=5
echo %date% %time% "Begin pause" >>%logfile%
timeout /t %timeout% /nobreak >nul
echo %date% %time% "End Pause" >>%logfile%

— Задаем папку srvinfo
eg_1541

set Dirreg1541="C:Program Files (x86)1cv8srvinfo
eg_1541" 

— Чистим сеансовые данные

:: Clear folder by mask
set n=0
pushd "%Dirreg1541%"
for /f %%i in (‘2#k8SjZc9Dxk>nul dir/ad/b "*snccntx*"’) do (
set/a n+=1
call set $%%n%%=%%i
)
popd (
if %n% equ 0 (
echo %date% %time% These folders not found. >>%logfile%
)
if %n% equ 1 (
pushd "%Dirreg1541%"
2>nul rd/q/s "%$1%"&& (
echo %date% %time% Clear the folder "%$1%". >>%logfile%
)|| (
echo %date% %time% folder "%$1%" was found, but to remove it completely failed. >>%logfile%
)
popd
)
if %n% gtr 1 (
echo %date% %time% These folders not found %n%: >>%logfile%
cmd/v/c "for /l %%i in (1 1 %n%) do @echo !$%%i!" >>%logfile%
)

— Задаем папку временных файлов для пользователя под кем запускается сервер 1С

set DirProg="C:UsersUSR1CV8AppDataLocalTemp"

— Чистим серверный кэш
:: Clear folder
PUSHD "%DirProg%"
2>Nul RD /S/Q "%DirProg%"
echo %date% %time% Clear the folder "%DirProg%". >>%logfile%
POPD

— Запускаем службу сервера 1С

:: Start the server agent service 1C
echo %date% %time% "net start Agent 1C">>%logfile%
net start %agent% >>%logfile%

— Ждем, пока запустится (необязательно)

:: pause
set timeout=10
echo %date% %time% "Begin pause" >>%logfile%
timeout /t %timeout% /nobreak >nul
echo %date% %time% "End Pause" >>%logfile%

— Конец батника 

Чтобы запускать Батник регулярно в установленное время, лучше воспользоваться Планировщиком заданий  Windows

  • Открыть "Планировщик Заданий"
  • Создать простую задачу
  • Выбрать расписание
  • Действие — "Запустить программу"
  • Выбрать наш батник
  • Завершить
  • Поставить галочку "Выполнить с наивысшими правами" (иначе не будет прав на перезапуск службы)
  • Поставить галочку "Выполнять вне зависимости от регистрации пользователя"  (чтобы выполнялось даже если мы не подключены к серверу)

Всё.

Пункты меню планировщика могут отличаться в зависимости от версии windows.

19 Comments

  1. YPermitin

    (0) Радикальное решение.

    С какими проблемами сталкиваетесь и на какой версии платформы, что приходиться так действовать?

    Reply
  2. alfir70

    (1) 8.3.13

    проблемы с памятью в основном

    Reply
  3. mrdc

    А не проще ли добавить памяти и перейти на 64-битную версию?

    Reply
  4. alfir70

    (3) памяти достаточно а вот для 64 битной — а пока невозможно

    Reply
  5. AronMav

    (2) Может лучше настроить локальный кластер на перезапуск как только он займет определенный объем оперативной памяти, а именно параметры «Допустимый объем памяти» и «Интервал превышения допустимого объема памяти»? Скриптом уж очень дерзко. Если есть проблемы кроме памяти, их нужно решать отдельно.

    Reply
  6. Nikola23

    (5) Не могу найти, эти параметры должны работать в Проф версии сервера или только в КОРП?

    Reply
  7. user612295_death4321

    (6) Формально ты можешь всеми этими ништяками пользоваться только а версии КОРП, но фактически оно функционирует и на ПРОФ, но использование на ПРОФ является нарушением лицензионного соглашения насколько я помню (могу быть неправ, либо информация могла измениться с какого времени).

    Reply
  8. oldcopy

    Там не все просто, есть различные варианты: http://1c.ru/news/info.jsp?id=25491

    Reply
  9. alfir70

    (5) да перезагрузка не только против памяти

    но и против других глюков платформы из-за кэша

    Reply
  10. GreenDragon

    (7) Как бы эти плюшки перестанут работать примерно в сентябре на профе. Ну, если конечно не апать платформу, то можно и после сентября (но так же с нарушением лиц. соглашения)

    Reply
  11. user612295_death4321

    (10) Есть какой то пруф или просто слухи ?

    Reply
  12. GreenDragon

    (11) Официальное письмо от 1С подойдёт? Попробую сейчас найти, но можете и сами прямо на инфостарте поискать в новостях — об этом уже давно говорят.

    Reply
  13. GreenDragon

    (11) https://infostart.ru/journal/news/mir-1s/1s-zakrepila-razdelenie-platformennykh-litsenziy-na-prof-i-korp_1002294/

    Ссылка на местную новость. В тексте ссылка на информационное письмо от 1С

    Reply
  14. AronMav

    (9) Выше все верно написали, скоро нужна будет версия КОРП для того, чтобы включить данные настройки. А какие именно проблемы были из-за кэша?

    Reply
  15. alfir70

    (14) в основном возникали при обновлении конфигурации, поэтому у перезагрузка сервера была привязана к обновлению конфигурации, также перед выгрузкой dt

    Reply
  16. Nikola23

    (11) Это ПРУФ.

    Потому и написал свое сообщение выше))

    Reply
  17. Painted

    За «timeout /t» лайк. ))

    Я до сих пор пингами пользовался ((

    Reply
  18. Arina1205777

    Не могу понять, почему у меня не отрабатывает батник до конца. Судя по логам проходит чистка сеансовых данных с результатом «These folders not found». А до «set DirProg=»C:UsersUSR1CV8AppDataLocalTemp»» уже не доходит. Служба не запускается. Можете подсказать в чем проблема?

    Reply
  19. alfir70

    (18) покажите пожалуйста весь лог из файла лога

    Reply

Leave a Comment

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