Удаление спящих сеансов

16.12.19

База данных - Администрирование СУБД

Удаление сеансов, имеющих статус "спящий".

Скачать файл

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

Наименование По подписке [?] Купить один файл
Удаление спящих сеансов:
.epf 8,00Kb
18
18 Скачать (1 SM) Купить за 1 850 руб.

Иногда возникает ситуация, когда настроенные ограничения спящих сеансов не срабатывают, и сервер 1С не только их "копит", даже по прошествии отведенного времени не закрывает, но и открывает их вновь "спящими" после полной перезагрузки сервера! Как бороться - есть разные способы, с перезапуском службы и очисткой кеша перед запуском, есть какие-то исполняемые файлы здесь на Инфостарте (но убивают все сеансы!).  Так или иначе, иногда хочется освободить память, и выкинуть таких "демонов". Пускать любого в админские права не хочется, поэтому сделал такую кнопку в самой УПП. Запускаем - все зависшие сеансы завершаются. Может, кому-то пригодится такая внешняя обработка...

Тестировалось на УПП 1.3.123.3, Платформа/сервер 8.3.15.1700.

УПП спящие зависшие сеансы сервер блокировки

См. также

Администрирование СУБД Системный администратор Платформа 1С v8.3 Бесплатно (free)

Пользовался ранее https://infostart.ru/1c/articles/1120161/#, но она устарела, т.к. службы запускаются через systemctl, да и сами службы слегка изменились. Возможно, где-то на ИТС уже есть нужная инструкция, но мне не попалась.

15.11.2024    298    Baser    2    

1

HighLoad оптимизация Администрирование СУБД Системный администратор Программист Платформа 1С v8.3 Россия Бесплатно (free)

Мы исследуем проблему долгого выполнения запросов PostgreSQL при использовании конструкции VALUES: когда она возникает, как на нее можно повлиять, а главное, почему ее продуманная отработка важна для более быстрого функционирования решений на базе 1С

12.11.2024    829    Tantor    19    

14

HighLoad оптимизация Администрирование СУБД Механизмы платформы 1С Программист Платформа 1С v8.3 ИТ-компания Россия Бесплатно (free)

В данной статье мы рассмотрим, как работает механизм временных таблиц на postgres на платформе 8.3.23 и что изменилось в нем при добавлении новых возможностей в платформе 8.3.25. А также на примере покажу, как понимание работы платформы позволяет оптимизировать СУБД для работы с 1С.

29.10.2024    3141    Tantor    38    

34

Администрирование СУБД Системный администратор Программист Бесплатно (free)

CDC - очень мощный механизм, который можно использовать во многих сценариях, возможность развернуть его в Docker показывает простоту и лёгкость данной технологии.

08.10.2024    733    AlexSvoykin    1    

7

Администрирование СУБД Системный администратор Программист Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

Анализ и решение ошибок СУБД. Во время реиндексации базы Ошибка СУБД: Microsoft SQL Server Native Client 11.0: Не удалось найти объект "ИмяБазы.dbo._RefSInf21806", так как он не существует, или отсутствуют разрешения. Во время проверки целостности Ошибка СУБД: Microsoft SQL Server Native Client 11.0: Недопустимое имя объекта "dbo._RefSInf21806".

19.09.2024    4348    Xershi    10    

17

HighLoad оптимизация Администрирование СУБД Архивирование (backup) Системный администратор Программист Платформа 1С v8.3 Бесплатно (free)

Бэкап в Postgres состоит из набора граблей, которые нужно обойти для успешного восстановления. Они заложены в самых неожиданных местах от предмета резервного копирования (база или кластер) до структуры каталогов. Один неверный шаг и восстановление будет невозможным. Почему нельзя было сделать проще, как в MS SQL или Oracle? Почему бэкап в Postgres оставляет впечатление чьей-то лабораторной работы? Статья адресована прежде всего специалистам 1С, избалованным комфортом в MS SQL, в суровых буднях импортозамещения на Postgres.

13.08.2024    2969    1CUnlimited    9    

4
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. cherva 97 18.12.19 11:09 Сейчас в теме
На платформе 8.3.14.1779 не работает
{ВнешняяОбработка.ВнешняяОбработка1.Форма.Форма.Форма(31)}: Метод объекта не обнаружен (ConnectAgent)
АгентСервера = COMСоединитель.ConnectAgent(ИдентификаторАгентаСервера);
2. &-rey 76 18.12.19 14:50 Сейчас в теме
COM не зарегистрирован, странно, может подключаетесь через тонкий клиент и пытается не на самом сервере искать подключение к серверу 1С?
3. cherva 97 18.12.19 16:09 Сейчас в теме
Предыдущую ошибку победили теперь это:


{ВнешняяОбработка.ВнешняяОбработка1.Форма.Форма.Форма(31)}: Ошибка при вызове метода контекста (ConnectAgent)
АгентСервера = COMСоединитель.ConnectAgent(ИдентификаторАгентаСервера);
по причине:
Произошла исключительная ситуация (V83.COMConnector.1): server_addr=tcp://mos1csrv:1540 descr=192.168.1.142:1540:10061(0x0000274D): Подключение не установлено, т.к. конечный компьютер отверг запрос на подключение. ;
line=1056 file=d:\jenkins\ci_builder\windowsbuild2\platform\src\rtrsrvc\src\d­ataexchangetcpclientimpl.cpp


У нас сервер на портах 17ХХ
4. &-rey 76 19.12.19 08:51 Сейчас в теме
порт у вас вроде бы стандартный 1540, все верно определилось, на 17хх у вас не сервер 1с наверное? Это видно по строке
"C:\Program Files\1cv8\8.3.15.1700\bin\ragent.exe" -srvc -agent -regport 1541 -port 1540 -range 1560:1591 -d "C:\Program Files\1cv8\srvinfo"
в свойствах службы агента сервера 1с, строка запуска....
тут вобщем то код пятиминутный, почти полностью дернут из общего модуля СоединенияИБКлиентСервер, функция ПолучитьАктивныеСеансыИБ. Затем из полученных перебираю и закрываю только спящие...


Процедура КнопкаВыполнитьНажатие(Кнопка)
	ПараметрыАдминистрированияИБ = СоединенияИБ.ПолучитьПараметрыАдминистрированияИБ(); 
	НастройкаБлокировки = ПараметрыАдминистрированияИБ;
	ВсеКромеТекущего = Истина;
	Результат = Новый Структура("АгентСервера,КластерСерверов,Сеансы", Неопределено, Неопределено, Новый Массив);
	
	ПодстрокиСтрокиСоединения = СтроковыеФункцииКлиентСервер.РазложитьСтрокуВМассивПодстрок(
	СтрокаСоединенияИнформационнойБазы(), ";");	
	ИмяСервера = СтроковыеФункцииКлиентСервер.СократитьДвойныеКавычки(Сред(ПодстрокиСтрокиСоединения[0], 7));
	ИмяИБ      = СтроковыеФункцииКлиентСервер.СократитьДвойныеКавычки(Сред(ПодстрокиСтрокиСоединения[1], 6));
	COMСоединитель = Новый COMОбъект(ОбщегоНазначения.ИмяCOMСоединителя());	
	РазделительПорта = Найти(ИмяСервера, ":");
	Если РазделительПорта > 0 Тогда
		ИмяИПортСервера = ИмяСервера;
		ИмяСервера = Сред(ИмяИПортСервера, 1, РазделительПорта - 1);
		НомерПортаКластера = Число(Сред(ИмяИПортСервера, РазделительПорта + 1));
	ИначеЕсли НастройкаБлокировки.ПортКластераСерверов <> 0 Тогда
		НомерПортаКластера = НастройкаБлокировки.ПортКластераСерверов;
	Иначе
		НомерПортаКластера = COMСоединитель.RMngrPortDefault;
	КонецЕсли;
	
	ИдентификаторАгентаСервера = ИмяСервера;
	Если НастройкаБлокировки.ПортАгентаСервера <> 0 Тогда
		ИдентификаторАгентаСервера = ИдентификаторАгентаСервера + ":" + 
			Формат(НастройкаБлокировки.ПортАгентаСервера, "ЧГ=0");
	КонецЕсли;
	
	// Подключение к агенту сервера
	АгентСервера = COMСоединитель.ConnectAgent(ИдентификаторАгентаСервера);
	Результат.АгентСервера = АгентСервера; 
	
	// Найдем необходимый нам кластер
	Для каждого Кластер Из АгентСервера.GetClusters() Цикл		
		Если Кластер.MainPort <> НомерПортаКластера Тогда
			Продолжить;
		КонецЕсли;		
		Результат.КластерСерверов = Кластер; 
		АгентСервера.Authenticate(Кластер, НастройкаБлокировки.ИмяАдминистратораКластера, 
			НастройкаБлокировки.ПарольАдминистратораКластера);		
		// Получаем список сеансов
		НомерТекущегоСеанса = СоединенияИБПовтИсп.ПараметрыОтключенияСеансов().НомерСеансаИнформационнойБазы;
		СписокСеансов = АгентСервера.GetSessions(Кластер);
		Для Каждого Сеанс из СписокСеансов Цикл
			Если ВРег(Сеанс.InfoBase.Name) <> ВРег(ИмяИБ) Тогда
				Продолжить;
			КонецЕсли;
			Если НЕ ВсеКромеТекущего ИЛИ (НомерТекущегоСеанса <> Сеанс.SessionID) Тогда
				Результат.Сеансы.Добавить(Сеанс);
			КонецЕсли;
		КонецЦикла;		
	КонецЦикла;

   //Теперь пройдемся по сеансам и если он спящий - выкинем
   Для каждого сеанс из Результат.Сеансы цикл
	   Если Сеанс.Hibernate тогда
		    СоединенияИБКлиентСервер.ОтключитьСеанс(сеанс.SessionID, "Злой админ послал вас на ...")
	   КонецЕсли;
   КонецЦикла;
   Предупреждение("ВСЕ ДЕМОНЫ УБИТЫ!!!", 5,"Удаление зависших сеансов");
   ЭтаФорма.Закрыть();
КонецПроцедуры
Показать
5. cherva 97 19.12.19 12:42 Сейчас в теме
нет сервер 1с у нас на портах 17Х. И в строка запуска 1С
\\ххххххх\1ce\1cestart.exe enterprise /Sхххххх:1741\gsiupp1 /RunModeOrdinaryApplication

Просто на 15ХХ стоит сервер 1С 8.2 , но он не запущен. А сервер 8.1 стоит именно на 17ХХ портах, может ваша обработка неправильно цепляет не тот сервер?
7. &-rey 76 19.12.19 17:00 Сейчас в теме
(5) Не путайте, это строка запуска толстого клиента. Если у вас два сервера установлено, вполне возможно он находит 8.2. В крайнем случае, посмотрите текст, там сперва поиск сервера формируется текстовая строка, задайте ее напрямую. К примеру НомерПортаКластера = "17хх", ИдентификаторАгентаСервера = "mos1csrv" и сразу пошло со строк // Подключение к агенту сервера

(6) Если бы это еще работало всегда... к сожалению, иногда какое время не ставь на засыпание и выкидывание, а они так и висят, да еще и с блокировками!... или ручками выкидывать, что надоело, сделал кнопку чтобы до переустановки сервера на НГ праздники юзеры сами могли очищать спящих
6. nomad_irk 76 19.12.19 12:50 Сейчас в теме
(0)Чем не устраивает типовой настраиваемый механизм завершения сеансов?
Оставьте свое сообщение