Регулярная перезагрузка Сервера 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.

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

См. также

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

Инструменты для разработчиков 1С 8.3: Infostart Toolkit. Автоматизация и ускорение разработки на управляемых формах. Легкость работы с 1С.

12000 руб.

02.09.2020    169302    937    403    

905

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

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

8400 руб.

20.08.2024    12613    99    42    

101

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

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

9360 руб.

17.05.2024    26538    90    48    

134

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

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

22200 руб.

06.10.2023    16830    41    15    

75

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

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

15000 руб.

10.11.2023    11397    40    27    

66

SALE! %

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

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

4800 3840 руб.

14.01.2013    190552    1150    0    

918

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

Разработка Конструктор автоматизированных рабочих мест "Конструктор АРМ" реализована в виде расширения и является универсальным инструментом для создания АРМ любой сложности в пользовательском режиме.

3600 руб.

27.12.2024    779    2    0    

4

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

Восстановление партий или взаиморасчетов, расчет зарплаты, пакетное формирование документов или отчетов - теперь все это стало доступнее. * Есть желание повысить скорость работы медленных алгоритмов! Но... * Нет времени думать о реализации многопоточности? * о запуске и остановке потоков? * о поддержании потоков в рабочем состоянии? * о передаче данных в потоки и как получить ответ из потока? * об организации последовательности? Тогда ЭТО - то что надо!!!

5000 руб.

07.02.2018    103934    244    100    

306
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
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 706 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 706 21.05.19 15:44 Сейчас в теме
(11) Это ПРУФ.
Потому и написал свое сообщение выше))
25. user1826876 27.12.24 13:12 Сейчас в теме
(7) Я извиняюсь, о каких ништяках идет речь? и что нарушает лицензионное соглашение?
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) Это не в батнике, в планировщике задается)
Оставьте свое сообщение