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

16.12.19

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

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

Скачать исходный код

Наименование Файл Версия Размер
Удаление спящих сеансов:
.epf 8,00Kb
18
.epf 8,00Kb 18 Скачать

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

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

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

См. также

Устранение ошибки выполнения скрипта "Создать сервис RAGENT" в ЦКК

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

В статье показано, как устранить ошибку выполнения скрипта "Создать сервис RAGENT" в системах 1С:Центр контроля качества или в 1С:Центр автоматизации. Будет полезна администраторам ЦКК и ЦА, которые только начали знакомство с этими системами.

вчера в 17:30    140    artemusII    0    

4

Долгая реструктуризация, замеры времени и очистка Ветис. Розница 2.3

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

При подготовке к обновлению возникли проблемы на стадии тестирования и исправления базы данных, также при создании файлов РИБ для магазинов.

16.04.2024    247    xKaskadx    4    

0

Установка и получение лицензии на базовую конфигурацию 1С на Mac OS

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

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

11.04.2024    344    pahmutov    0    

2

Установка тонкого клиента 1С на Rasbian (Raspberry Pi 5)

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

После приобретения Raspberry Pi 5 решил проверить, есть ли возможность использования устройства для организации тонкого клиента. В результате столкнулся с особенностью установки 1С: Предприятие 8.3.23 на Raspbian, решением которой я хочу поделиться с сообществом.

07.04.2024    607    Bessome    3    

5

Порционный шринк базы

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

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

28.03.2024    1271    Garilia    3    

15

Создаем сценарии обслуживания SQL в Центре Контроля Качества 1С (Центр Администрирования)

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

Данная статья научит вас, как создавать скрипты обслуживания MS SQL для Центра Контроля Качества (ЦКК) или Центра Администрирования (ЦА).

20.03.2024    742    Silenser    0    

5

Поинтегрируем: сервисы интеграции – новый стандарт или просто коннектор?

Обмен между базами 1C Администрирование СУБД Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

В платформе 8.3.17 появился замечательный механизм «Сервисы интеграции». Многие считают, что это просто коннектор 1С:Шины. Так ли это?

11.03.2024    5912    dsdred    53    

83

Инструкция по установке Postgres для OLTP приложений и 1С. Часть 1. Базовая конфигурация

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

В Postgres достаточно подробная документация, и, видимо, поэтому при инсталляции Postgres для 1С большинство параметров приходится выставлять самим. Параметров в Postgres много, а составить эффективную комбинацию не так просто. Все упрощается, если рассмотреть профиль нагрузки, например, 1С это прежде всего профиль OLTP нагрузки – так устроены его метаданные (объекты). Если сосредоточиться на оптимизации профиля OLTP, понимание Postgres сразу упростится.

15.02.2024    2541    1CUnlimited    14    

28
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. cherva 97 18.12.19 11:09 Сейчас в теме
На платформе 8.3.14.1779 не работает
{ВнешняяОбработка.ВнешняяОбработка1.Форма.Форма.Форма(31)}: Метод объекта не обнаружен (ConnectAgent)
АгентСервера = COMСоединитель.ConnectAgent(ИдентификаторАгентаСервера);
2. &-rey 75 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 75 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 75 19.12.19 17:00 Сейчас в теме
(5) Не путайте, это строка запуска толстого клиента. Если у вас два сервера установлено, вполне возможно он находит 8.2. В крайнем случае, посмотрите текст, там сперва поиск сервера формируется текстовая строка, задайте ее напрямую. К примеру НомерПортаКластера = "17хх", ИдентификаторАгентаСервера = "mos1csrv" и сразу пошло со строк // Подключение к агенту сервера

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