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

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

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

Перезагрузка сервера Кэш сеансовые данные автоматическая

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

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

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

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

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

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

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

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

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

set logfile="\\localhost\log\LOG_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\reg_1541

set Dirreg1541="C:\Program Files (x86)\1cv8\srvinfo\reg_1541" 

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

:: Clear folder by mask
set n=0
pushd "%Dirreg1541%"
for /f %%i in ('2^>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:\Users\USR1CV8\AppData\Local\Temp\"

-- Чистим серверный кэш
:: 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.

43

См. также

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

Комментарии
Избранное Подписка Сортировка: Древо
1. YPermitin 2512 17.05.19 14:38 Сейчас в теме
(0) Радикальное решение.

С какими проблемами сталкиваетесь и на какой версии платформы, что приходиться так действовать?
Артано; +1 Ответить
2. alfir70 158 17.05.19 15:29 Сейчас в теме
(1) 8.3.13
проблемы с памятью в основном
5. AronMav 17.05.19 17:52 Сейчас в теме
(2) Может лучше настроить локальный кластер на перезапуск как только он займет определенный объем оперативной памяти, а именно параметры "Допустимый объем памяти" и "Интервал превышения допустимого объема памяти"? Скриптом уж очень дерзко. Если есть проблемы кроме памяти, их нужно решать отдельно.
GreenDragon; SerVer1C; YPermitin; zeegin; Xershi; +5 Ответить
6. Nikola23 415 19.05.19 15:52 Сейчас в теме
(5) Не могу найти, эти параметры должны работать в Проф версии сервера или только в КОРП?
7. user612295_death4321 19.05.19 18:07 Сейчас в теме
(6) Формально ты можешь всеми этими ништяками пользоваться только а версии КОРП, но фактически оно функционирует и на ПРОФ, но использование на ПРОФ является нарушением лицензионного соглашения насколько я помню (могу быть неправ, либо информация могла измениться с какого времени).
10. GreenDragon 20.05.19 10:19 Сейчас в теме
(7) Как бы эти плюшки перестанут работать примерно в сентябре на профе. Ну, если конечно не апать платформу, то можно и после сентября (но так же с нарушением лиц. соглашения)
11. user612295_death4321 20.05.19 10:53 Сейчас в теме
(10) Есть какой то пруф или просто слухи ?
12. GreenDragon 20.05.19 10:56 Сейчас в теме
(11) Официальное письмо от 1С подойдёт? Попробую сейчас найти, но можете и сами прямо на инфостарте поискать в новостях - об этом уже давно говорят.
13. GreenDragon 20.05.19 10:57 Сейчас в теме
(11) https://infostart.ru/journal/news/mir-1s/1s-zakrepila-razdelenie-platformennykh-litsenziy-na-prof-i-korp_1002294/
Ссылка на местную новость. В тексте ссылка на информационное письмо от 1С
16. Nikola23 415 21.05.19 15:44 Сейчас в теме
(11) Это ПРУФ.
Потому и написал свое сообщение выше))
9. alfir70 158 20.05.19 09:50 Сейчас в теме
(5) да перезагрузка не только против памяти
но и против других глюков платформы из-за кэша
14. AronMav 20.05.19 17:45 Сейчас в теме
(9) Выше все верно написали, скоро нужна будет версия КОРП для того, чтобы включить данные настройки. А какие именно проблемы были из-за кэша?
15. alfir70 158 21.05.19 09:08 Сейчас в теме
(14) в основном возникали при обновлении конфигурации, поэтому у перезагрузка сервера была привязана к обновлению конфигурации, также перед выгрузкой dt
3. mrdc 17.05.19 16:46 Сейчас в теме
А не проще ли добавить памяти и перейти на 64-битную версию?
4. alfir70 158 17.05.19 17:44 Сейчас в теме
(3) памяти достаточно а вот для 64 битной - а пока невозможно
8. oldcopy 120 19.05.19 19:21 Сейчас в теме
Там не все просто, есть различные варианты: http://1c.ru/news/info.jsp?id=25491
17. Painted 25 24.05.19 11:03 Сейчас в теме
За "timeout /t" лайк. ))
Я до сих пор пингами пользовался ((
Оставьте свое сообщение