WEB – сервис для закрытия сеансов 1с на Node.js.

01.09.16

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

Простой веб-сервис для сброса сессий 1с на сервере или пример того как подружить V83.COMConnector и Node.js

Скачать файлы

Наименование Файл Версия Размер
sesions
.rar 780,50Kb
10
.rar 1.0 780,50Kb 10 Скачать

Зачем и почему :

Ни для кого не секрет, что время от времени некоторые сеансы могут зависать на сервере, и блокируя какие-нибудь объекты в базе препятствовать  работе пользователей. Причины этого могут быть совершенно разные, например проблемы с сетью, перебои с питанием, зависание компьютера.

Когда база маленькая и пользователей мало, то можно просто зайти в консоль  сервера 1с  сбросить сеанс кому нужно. Рано или поздно у программистов появляется желание это как-нибудь упростить/автоматизировать  с помощью 1С через V83.COMConnector  и это я считаю логично.

Но что делать таким «счастливчикам»    у которых доступа к серверу нету и V83.COMConnector на сервере не поднимается, только просить админов его зарегистрировать. А админы не настраивают (не хотят/не могут/нету времени). А если еще в кластере несколько серверов  то на каждом надо COM-компоненту настроить, и при обновлении релиза у нас во всяком случае обязательно слетает.

Все эти неудобства и натолкнули меня на мысль что было бы неплохо иметь веб-сервис который будет крутится на машинке которую администрирую непосредственно я. То есть поднимать   V83.COMConnector  по запросу пользователя и сбрасывать нужный  сеанс.

Реализация :

Пишем простенькую страничку с одним полем для ввода данных и одной кнопкой.  По нажатии кнопки данные о номере сеанса передаются на сервер, где с помощью пакета edge выполняется процедура на C# которая на входе принимает номер сеанса , поднимает  объект V83.COMConnector , и пытается убить нужный сеанс. Далее отображаем результат в консоль сервера и возвращаем ответ пользователю.

Для тех кому интересно попробовать - инструкция по установке  :

  1. Устанавливаем Node.js , у себя использую версию 5.6.0 (https://nodejs.org/download/release/v5.6.0/)
  2. Распаковываем скачанный архив в удобное нам место.
  3. Запускаем консоль (cmd.exe) и заходим в папку проекта (sesions)  пишем 
    npm install
    и пакетный менеджер ноды выкачает нам в эту же папку все необходимые зависимости.
  4. Далее  нам необходимо прописать данные для подключения к базе – открываем файл с именем com_api.js  и заполняем значения переменным:
        string server_name="ИмяСервера ";
        string cl_admin_name="ЛогинАдминаКластераСерверов";
        string cl_admin_pass="ПарольАдминаКластераСерверов";
        string base_name="ИмяНашейБазы";

    5. Запускаем выполнив в консоли из той же папки команду

    node server.js

*** Если при установке зависимостей edge не устанавливается – то сначала ставим еще «Microsoft .NET Framework 4.5» (https://www.microsoft.com/ru-RU/download/details.aspx?id=30653) и после установки выполняем пункт  3

*** Еще небольшой нюанс здесь код из расчета на то что в кластере  1 сервер и сеансы в консоли не задваиваются. Если в кластере к примеру 2 сервера и в консоли вы видите задвоенные сеансы – то в строке 30 файла com_api.js  нужно в условии  прописать

flag_first == 2

 Просто натолкнулся уже на это и корректно отрабатывает если при такой ситуации убивать именно второй сеанс.

node.js веб-сервис закрытие сеансов

См. также

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

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

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

12000 руб.

02.09.2020    115311    630    389    

683

Infostart PrintWizard

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

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

18000 руб.

06.10.2023    6396    13    3    

35

SALE! 30%

PowerTools

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

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

3600 2520 руб.

14.01.2013    176322    1063    0    

838

Infostart УДиФ: Управление данными и формами

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

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

10000 руб.

10.11.2023    2646    4    1    

26

Многопоточность. Универсальный «Менеджер потоков» 2.1

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

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

5000 руб.

07.02.2018    98577    239    97    

292

Выполнение произвольного кода или запроса с параметрами через Web-сервис (замена COM-подключений)

Инструментарий разработчика Обмен между базами 1C Платформа 1С v8.3 Платные (руб)

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

2400 руб.

24.09.2019    23217    15    15    

30

Менеджер конфигураций 1С

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

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

1800 руб.

21.02.2023    6304    4    34    

16

Программное формирование существующих печатных форм

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

Получение списка печатных форм, формирование выбранной печатной формы и сохранение ее в файл.

1 стартмани

17.12.2021    15453    42    RocKeR_13    5    

49
Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. andy23 467 01.09.16 14:44 Сейчас в теме
Задумка хорошая. Для данной задачи в качестве веб-сервера можно использовать вместо express, что-нибудь попроще, например node-static.
Чтобы не утруждать пользователя установками можно использовать портативную версию node.js Таким образом у меня реализован монитор журнала регистрации.
Чтобы сбросить сессию - нужно ввести ее номер, может сделать табличку, где будут выводится номера всех сессий и от туда можно было выбрать и сбросить.
edge.js для внедрения C# - эх как я искал такую штуку раньше, видимо недавно появилась...
Оставьте свое сообщение