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

17.05.19

Разработка - Инструментарий разработчика

Батник для перезагрузки агента сервера 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.

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

См. также

SALE! 15%

Инструментарий разработчика Роли и права Запросы СКД Программист Платформа 1С v8.3 Управляемые формы Запросы Система компоновки данных Конфигурации 1cv8 Платные (руб)

Набор инструментов программиста и специалиста 1С для всех конфигураций на управляемых формах. В состав входят инструменты: Консоль запросов, Консоль СКД, Консоль кода, Редактор объекта, Анализ прав доступа, Метаданные, Поиск ссылок, Сравнение объектов, Все функции, Подписки на события и др. Редактор запросов и кода с раскраской и контекстной подсказкой. Доработанный конструктор запросов тонкого клиента. Продукт хорошо оптимизирован и обладает самым широким функционалом среди всех инструментов, представленных на рынке.

10000 руб.

02.09.2020    159666    875    399    

862

SALE! 15%

Инструментарий разработчика Чистка данных Свертка базы Инструменты администратора БД Системный администратор Программист Руководитель проекта Платформа 1С v8.3 Конфигурации 1cv8 1С:Управление торговлей 10 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 Россия Платные (руб)

Инструмент представляет собой обработку для проведения свёртки или обрезки баз данных. Работает на ЛЮБЫХ конфигурациях (УТ, БП, ERP и т.д.). Поддерживаются управляемые и обычные формы. Может выполнять свертку сразу нескольких баз данных и выполнять их автоматически без непосредственного участия пользователя.

8400 7140 руб.

20.08.2024    7869    58    23    

69

Инструментарий разработчика Программист Платформа 1С v8.3 Конфигурации 1cv8 Платные (руб)

Инструмент для написания и отладки кода в режиме «1С:Предприятие». Представляет собой консоль кода с возможностью пошаговой отладки, просмотра значений переменных любых типов, использования процедур и функций, просмотра стека вызовов, вычисления произвольных выражений на встроенном языке в контексте точки останова, синтаксического контроля и остановки по ошибке. В консоли используется удобный редактор кода с подсветкой, контекстной подсказкой, возможностью вызова конструкторов запроса и форматной строки.

9360 руб.

17.05.2024    23495    68    45    

117

SALE! 15%

Инструменты администратора БД Инструментарий разработчика Роли и права Программист Платформа 1С v8.3 Конфигурации 1cv8 Россия Платные (руб)

Расширение позволяет без изменения кода конфигурации выполнять проверки при вводе данных, скрывать от пользователя недоступные ему данные, выполнять код в обработчиках. Не изменяет данные конфигурации, легко устанавливается практически на любую конфигурацию на управляемых формах.

10000 8500 руб.

10.11.2023    10462    36    25    

61

SALE! 15%

Пакетная печать Печатные формы Инструментарий разработчика Программист Платформа 1С v8.3 Запросы 1С:Зарплата и кадры бюджетного учреждения 1С:Конвертация данных 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 Платные (руб)

Инструмент, позволяющий абсолютно по-новому взглянуть на процесс разработки печатных форм. Благодаря конструктору можно значительно снизить затраты времени на разработку печатных форм, повысить качество и "прозрачность" разработки, а также навести порядок в многообразии корпоративных печатных форм.

22200 19980 руб.

06.10.2023    15431    35    7    

70

SALE! 35%

Инструментарий разработчика Инструменты администратора БД Системный администратор Программист Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Россия Платные (руб)

Универсальный инструмент программиста для администрирования конфигураций. Сборник наиболее часто используемых обработок под единым интерфейсом.

4800 3120 руб.

14.01.2013    188048    1140    0    

912

SALE! 15%

Инструментарий разработчика Программист 8.3.14 1С:Конвертация данных Россия Платные (руб)

Расширение для конфигурации “Конвертация данных 3”. Добавляет подсветку синтаксиса, детальную контекстную подсказку, глобальный поиск по коду.

15000 12750 руб.

07.10.2021    17318    6    32    

42

Инструментарий разработчика Программист Платные (руб)

Менеджер конфигураций 1С — альтернативный стартер информационных баз 1С:Предприятие.

1800 руб.

21.02.2023    7717    8    35    

23
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. пользователь 17.05.19 14:38
(0) Радикальное решение.

С какими проблемами сталкиваетесь и на какой версии платформы, что приходиться так действовать?
Артано; +1 Ответить
2. alfir70 195 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 705 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 705 21.05.19 15:44 Сейчас в теме
(11) Это ПРУФ.
Потому и написал свое сообщение выше))
9. alfir70 195 20.05.19 09:50 Сейчас в теме
(5) да перезагрузка не только против памяти
но и против других глюков платформы из-за кэша
14. AronMav 20.05.19 17:45 Сейчас в теме
(9) Выше все верно написали, скоро нужна будет версия КОРП для того, чтобы включить данные настройки. А какие именно проблемы были из-за кэша?
15. alfir70 195 21.05.19 09:08 Сейчас в теме
(14) в основном возникали при обновлении конфигурации, поэтому у перезагрузка сервера была привязана к обновлению конфигурации, также перед выгрузкой dt
22. siamagic 18.07.24 20:09 Сейчас в теме
(5) Чем это будет отличатся от выполненного выше?
3. mrdc 17.05.19 16:46 Сейчас в теме
А не проще ли добавить памяти и перейти на 64-битную версию?
4. alfir70 195 17.05.19 17:44 Сейчас в теме
(3) памяти достаточно а вот для 64 битной - а пока невозможно
8. oldcopy 174 19.05.19 19:21 Сейчас в теме
Там не все просто, есть различные варианты: http://1c.ru/news/info.jsp?id=25491
17. Painted 49 24.05.19 11:03 Сейчас в теме
За "timeout /t" лайк. ))
Я до сих пор пингами пользовался ((
Itilive.ru; autosvg; +2 Ответить
23. mefalcon 36 09.08.24 11:20 Сейчас в теме
(17) таймаут я бы заменил проверкой остановки процесса, либо тасккилл (но второе спорно)
18. Arina1205777 25.06.19 16:06 Сейчас в теме
Не могу понять, почему у меня не отрабатывает батник до конца. Судя по логам проходит чистка сеансовых данных с результатом "These folders not found". А до "set DirProg="C:\Users\USR1CV8\AppData\Local\Temp\"" уже не доходит. Служба не запускается. Можете подсказать в чем проблема?
19. alfir70 195 08.07.19 10:43 Сейчас в теме
(18) покажите пожалуйста весь лог из файла лога
user1518146; +1 Ответить
20. Nuuq 76 09.08.21 12:46 Сейчас в теме
(18) Нужно путь к каталогу просто указать через двойную кавычку, т.к. там присутствует пробел и CMD на этом месте останавливается. Т.е. в том месте где "-- Задаем папку srvinfo\reg_1541"
вместо
set Dirreg1541="C:\Program Files (x86)\1cv8\srvinfo\reg_1541"

сделать
set Dirreg1541=""C:\Program Files (x86)\1cv8\srvinfo\reg_1541""
21. ennerlink 22.05.24 19:25 Сейчас в теме
Можно немного модифицировать скрипт, чтобы был универсальным, например запуск Сервера 1С происходит от имени системной учетной записи, а не пользователя USR1CV8
24. mefalcon 36 09.08.24 11:22 Сейчас в теме
(21) Это не в батнике, в планировщике задается)
Оставьте свое сообщение