Удаление неактивных и повторно запущенных пользователем сеансов - обработкой в фоне или внешней обработкой

28.04.22

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

На экране монитора при запуске конфигурации нередко приходится видеть обидное сообщение "Не обнаружено свободной лицензии". Особенно это актуально, когда у вас 100 лицензий и при этом работает порядка 90 пользователей. При этом, очень актуальна жесткая политика - "Один сеанс в одни руки". Для автоматизации ручной работы администратора 1С по удалению сеансов пользователей и предназначена данная обработка. Обработка может быть использована как внешняя, так и поставлена в дополнительные отчеты и обработки с установкой расписания запуска, в этом случае обработка будет выполняться как фоновое задание. Обработка предназначена для работы в клиент-серверных базах и тестировалась на платформе 8.3.14.1854. Обработка установленная на платформе не ниже 8.3.6, позволяет управлять сеансами конфигураций установленных на платформе 8.2

Скачать файл

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование По подписке [?] Купить один файл
Удаление не активных и повторно запущенных пользователем сеансов - обработкой в фоне или внешней обработкой:
.epf 12,78Kb ver:1.1
42
42 Скачать (3 SM) Купить за 2 450 руб.

1. Работа внешней обработки.

    При запуске обработки автоматически заполняются реквизиты "Адрес сервера" и "Имя базы". При необходимости эти данные можно поменять в ручную и подключиться к другой базе. Если запустить обработку на файловой конфигурации, то эти реквизиты необходимо занести в ручную. Если на кластер 1С установлен пароль администратора, то его пароль и логин заносятся в реквизиты "Пароль" и "Имя администратора". 

    В реквизит "Время опроса мин", заносится период опроса сеансов базы данных. Минимальное время 1 мин. Если разница во времени между текущим временем и временем последней активности сеанса будет больше установленого числа в реквизите "Время неактивности сеанса мин", то сеанс будет считаться не активным и будет удален.

    Реквизиты "Мониторинг запущен" и "Количество опросов" с момента запуска мониторинга, являются информационными.

    Управление обработкой осуществляется кнопками:

"Одиночный опрос"- осуществляет один опос сеансов пользователей базы;

"Начать мониторинг" - запускает непрерывный опрос сеансов пользователей с частотой 1 раз в период установленный в реквизите "Время опроса мин" ;

"Остановить мониторинг" - останавливает мониторинг сеансов пользователей.

     Кроме не активных сеансов будут удаляться сеансы повторно запущенных пользователями "тонкого" и "толстого" клиентов. Удален будет сеанс с наименьшим временем активности. Таким образом реализована политика "Один сеанс в одни руки"

        Таблица "ПротоколУдаленияСеансов", содержит строки удаленных сеансов базы данных.

2. Работа в режиме фонового задания

     Для работы обработки в режиме фонового задания, её необходимо установить в дополнительные обработки и настроить расписание запуска.

   

После этого в "Регламентных и фоновых заданиях" выбрать пользователя с правами "Администратор", под которым будет запускаться обработка.

    При необходимости отредактировать код вызова процедуры мониторинга. Заполняем ИмяАдминистратора и ПарольАдминистратора, если они установлены и меняем ВремяНеактивностиСеансаМин, по умолчанию 80 мин.

Перем Команда_Мониторинг_Сеансов Экспорт;
Перем ТабУдалСеансов;
Перем ПутьКПротоколуУдаленияСеансов;

Функция СведенияОВнешнейОбработке() Экспорт
	
	РегистрационныеДанные = Новый Структура;
	РегистрационныеДанные.Вставить("Вид", "ДополнительнаяОбработка");
	РегистрационныеДанные.Вставить("Наименование", "Мониторинг сеансов в фоне");
	РегистрационныеДанные.Вставить("Версия", "1.0");
	РегистрационныеДанные.Вставить("БезопасныйРежим", Ложь);
	РегистрационныеДанные.Вставить("Информация", "Мониторинг сеансов в фоне");

	ТЗКоманды = Новый ТаблицаЗначений;
	ТЗКоманды.Колонки.Добавить("Идентификатор");
	ТЗКоманды.Колонки.Добавить("Представление");
	ТЗКоманды.Колонки.Добавить("Модификатор");
	ТЗКоманды.Колонки.Добавить("ПоказыватьОповещение");
	ТЗКоманды.Колонки.Добавить("Использование");

	СтрокаКоманды = ТЗКоманды.Добавить();
	СтрокаКоманды.Представление = "Мониторинг сеансов в фоне";
	СтрокаКоманды.ПоказыватьОповещение = Ложь;
	СтрокаКоманды.Использование = "ВызовСерверногоМетода";
	СтрокаКоманды.Идентификатор = "Команда_Мониторинг_Сеансов";

	РегистрационныеДанные.Вставить("Команды", ТЗКоманды);

	Возврат РегистрационныеДанные;
	
КонецФункции

Процедура ВыполнитьКоманду(ИдентификаторКоманды) Экспорт	
	
	УстановитьПривилегированныйРежим(Истина);
	ПараметрыСеанса.ПризнакОтключенияКонтроляНастроек = Истина;
	Если ИдентификаторКоманды = Команда_Мониторинг_Сеансов Тогда

// Здесь редактируем параметры запуска процедуры мониторинга	
		НачатьМониторингСеансов(,,,80);

	КонецЕсли;	
	ПараметрыСеанса.ПризнакОтключенияКонтроляНастроек = Ложь;
	УстановитьПривилегированныйРежим(Ложь);

КонецПроцедуры

Функция НачатьМониторингСеансов(ИмяАдминистратора="", ПарольАдминистратора="", ЗапускИзФормы=Ложь, ВремяНеактивностиСеансаМин=60) Экспорт

 С настройкой вызова все. Но если мы хотим писать протокол удаленных сеансов то необходимо в переменную ПутьКПротоколуУдаленияСеансов записать путь к папке на сервере 1с для файла, в который будет писаться информация по удаленным сеансам всех баз данных с установленным фоновым заданием "Мониторинг сеансов в фоне".

Процедура ЗаполнитьПротоколУдаления()
	
	КаталогНаДиске = Новый Файл(ПутьКПротоколуУдаленияСеансов);
    Если не КаталогНаДиске.Существует() Тогда
        Возврат;
	КонецЕсли; 
	
	Текст = Новый ЗаписьТекста(ПутьКПротоколуУдаленияСеансов+"\Протокол.txt", КодировкаТекста.ANSI, Символы.ВК + Символы.ПС, Истина); 
	Для Каждого Строка Из ТабУдалСеансов Цикл
		Текст.ЗаписатьСтроку(Строка.Пользователь+"|"+Строка.ИдСеанса+"|"+Строка.Приложение+"|"+Строка.ТипУдаления+"|"+Строка.ДатаУдаления+"|"+Строка.ИмяБазы);
	КонецЦикла;	
	Текст.Закрыть();
	 
КонецПроцедуры	


Команда_Мониторинг_Сеансов = "Команда_Мониторинг_Сеансов";
ТабУдалСеансов = Новый ТаблицаЗначений;
ТабУдалСеансов.Колонки.Добавить("ИдСеанса", Новый ОписаниеТипов("Число"));
ТабУдалСеансов.Колонки.Добавить("Пользователь");
ТабУдалСеансов.Колонки.Добавить("Приложение");
ТабУдалСеансов.Колонки.Добавить("ТипУдаления", Новый ОписаниеТипов("Число"));
ТабУдалСеансов.Колонки.Добавить("ДатаУдаления", Новый ОписаниеТипов("Дата"));
ТабУдалСеансов.Колонки.Добавить("ИмяБазы");

//ПутьКПротоколуУдаленияСеансов = "C:\РНГ\ПротоколУдаленияСеансов";
ПутьКПротоколуУдаленияСеансов = "";

    Если переменная ПутьКПротоколуУдаленияСеансов = "", то протокол , в текстовый файл "Протокол.txt", писаться не будет. Если указанная вами папка на сервере 1с отсутствует, то протокол так же не пишется. Пользователь под которым запускается обработка, как фоновое задание должен иметь права на создание и редакцию файлов в папке протоколов.

          Версия 1.1

   Добавлен реквизит логического типа "МониторингВсехБаз". Установка в значение "Истина" позволяет осуществлять мониторинг всех баз крастера серверов 1с.

   В режиме фонового задания этот же режим достигается установкой параметра МониторингВсехБаз=Истина

//Робота по всем базам в фоне	
Функция НачатьМониторингСеансов(ИмяАдминистратора="", ПарольАдминистратора="", ЗапускИзФормы=Ложь, ВремяНеактивностиСеансаМин=60, МониторингВсехБаз=Истина) Экспорт
//Функция НачатьМониторингСеансов(ИмяАдминистратора="", ПарольАдминистратора="", ЗапускИзФормы=Ложь, ВремяНеактивностиСеансаМин=60, МониторингВсехБаз=Ложь) Экспорт

   В результате поставив обработку в качестве фонового задания на обну базу, мы можем удалять сеансы по всем базам крастера серверов 1с.

См. также

Журнал регистрации Мониторинг Системный администратор Программист Бизнес-аналитик Руководитель проекта Платформа 1С v8.3 Платные (руб)

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

9000 руб.

28.08.2019    33924    22    21    

74

Учет доходов и расходов Логистика, склад и ТМЦ Маркетплейсы Мониторинг Пользователь Платформа 1С v8.3 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Розничная и сетевая торговля (FMCG) Оптовая торговля, дистрибуция, логистика Управленческий учет Платные (руб)

Расширение модуля Synchrozon для удобного контроля габаритов на Ozon! Разработка позволяет мгновенно сравнивать установленные габариты товаров, с габаритами, указанными на Ozon, чтобы выявлять любые несоответствия. Поможет сократить расходы на логистику, гарантируя, что все данные о товарах остаются точными и актуальными.

3600 руб.

31.10.2024    338    1    0    

3

Мониторинг Системный администратор Программист Платформа 1С v8.3 Россия Платные (руб)

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

3600 руб.

03.05.2023    5101    3    0    

3

Мониторинг Инструменты администратора БД Системный администратор Платформа 1С v8.3 Россия Платные (руб)

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

1500 руб.

01.12.2020    15988    38    0    

56

Логистика, склад и ТМЦ Мониторинг Маркетплейсы Комплексное управление ресурсами (ERP) Пользователь Платформа 1С v8.3 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Розничная и сетевая торговля (FMCG) Оптовая торговля, дистрибуция, логистика Платные (руб)

Разработка «Ловец коэффициентов складов Wildberries» — расширение для 1С, которое автоматически «отлавливает» тарифы складов с наиболее выгодными коэффициентами для ваших товаров на маркетплейсе Wildberries. С помощью этого инструмента вы сможете легко находить и выбирать склады с лучшими условиями для максимизации своей прибыли. Удобная интеграция позволяет настроить регулярный поиск складов по выгодным коэффициентам в виде регламентного задания в 1С, что существенно экономит время и автоматизирует процесс принятия решений по размещению товаров. Всегда будьте на шаг впереди конкурентов и повышайте эффективность своего бизнеса с помощью «Ловца коэффициентов складов Wildberries»!

3600 руб.

14.11.2024    224    0    0    

2

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

Решение для управления ключевыми показателями компании, обеспечивающее гибкую настройку, визуализацию данных и эффективный контроль за достижением целей. Продукт сокращает трудозатраты на расчет и аналитику, позволяя быстрее принимать обоснованные решения. Легко интегрируется в любую конфигурацию 1С, предлагая интуитивный интерфейс, удобный для всех пользователей.

24000 руб.

11.11.2024    183    0    0    

0

Мониторинг Сервера Системный администратор Платформа 1С v8.3 Конфигурации 1cv8 Россия Абонемент ($m)

StartPlus и система контроля и сбора информации (настраиваем за час и пользуемся). Данное решение позволяет быстро собирать и анализировать различную информацию из разных источников данных (не обязательно серверов 1С). В любой момент можно менять состав сводной информации без сложной разработки на стороне 1С.

1 стартмани

18.07.2024    848    7    moolex    0    

5

Мониторинг Системный администратор Программист Платформа 1С v8.3 Конфигурации 1cv8 Абонемент ($m)

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

1 стартмани

13.06.2024    4976    37    Garilia    3    

36
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. Van2507 12 13.11.19 14:22 Сейчас в теме
Полезная обработка. На сколько я знаю в самой платформе еще есть функционал, позволяющий завершать спящие сеансы. Время засыпания, также как и отключения спящих сеансов устанавливается вручную.
Прикрепленные файлы:
3. AnatolPopov 173 13.11.19 16:30 Сейчас в теме
(1) Мой опыт говорит, что тот функционал работает как хочет. Я немного обсуждаю его вот здесь:
https://infostart.ru/public/1125306/
Процитирую себя:
"Средства, предусмотренные на этот случай разработчиками платформы (Конфигуратор – Администрирование – Параметры ИБ – Время засыпания пассивного сеанса, Время завершения спящего сеанса), почему-то работали как хотели и не гарантировали результат. Возможно, они до сих пор точно так же халтурят. Давно не проверял за ненадобностью."
"... Кроме того, параметр «Время засыпания пассивного сеанса» все-таки чаще работает, чем не работает. Можно увеличить его с традиционных 20 минут до часа, и это сильно сократит количество жалоб."
nnnnnndfge; Jejer; +2 Ответить
4. Van2507 12 13.11.19 16:38 Сейчас в теме
(3) Пару недель назад проверяли этот способ, вроде все работает, по крайней мере зависшие сеансы прошлых дат перестали появлятся
2. AnatolPopov 173 13.11.19 16:24 Сейчас в теме
При этом, очень актуальна жесткая политика - "Один сеанс в одни руки"

Сурово...
Я как-то привык, что моим подопечным всю жизнь надо по два сеанса:
- БГУ и ЗКГУ
- БП и ЗУП
- БГУ и прошлогодняя копия БГУ
- что-то еще и что-то еще
5. IVC_goal 226 13.11.19 18:11 Сейчас в теме
(2) Речь идет - один сеанс к одной базе, учитываются только сеансы с "толстым" и "тонким" клиентами
6. пользователь 14.11.19 08:04
Сообщение было скрыто модератором.
...
7. dimisa 137 12.03.20 20:30 Сейчас в теме
В модуле объекта
1.
закомментил или попытка (не во всех конфигурациях есть)
{
ПараметрыСеанса.ПризнакОтключенияКонтроляНастроек = Истина;
ПараметрыСеанса.ПризнакОтключенияКонтроляНастроек = Ложь;
}

2. спасибо нашёл
{
Если ИмяПользователя = Сеанс.userName ИЛИ не СтрНайти( "1CV8,1CV8C,WebClient", Сеанс.AppID) > 0 Тогда
}

нужна ли конструкция "ИмяПользователя = Сеанс.userName" если фоновое задание ?
8. IVC_goal 226 13.03.20 07:52 Сейчас в теме
(7)
нужна ли конструкция "ИмяПользователя = Сеанс.userName" если фоновое задание ?


Нет не нужна
10. Svet_Serg 23.03.20 09:39 Сейчас в теме
(8) Спасибо за обработку. Не подошла(
9. Svet_Serg 16.03.20 15:12 Сейчас в теме
1С:Предприятие 8.3 (8.3.15.1778)
Документооборот 8 КОРП, редакция 2.1 (2.1.16.1)

На такой конфигурации сработает, как считаете? Жалко потратить с трудом добытый стартмани и узнать, что не подойдет)
11. user1581001 07.05.21 00:57 Сейчас в теме
Будет ли обработка работать на УТ 10.3?
12. IVC_goal 226 07.05.21 06:17 Сейчас в теме
(11) Нет. Под неуправляемыми формами обработка работать не будет. Из конфигурации под управляемыми формами, обработка может управлять сеансами УТ 10.3. Если переделать регистрацию обработки под неуправляемые формы, то возможно в фоновых заданиях обработка и сможет работать, но этот не точно. Этот вариант работы не тестировался.
Оставьте свое сообщение