Подключение двух и более COMConnector'ов (COM-соединений) к различным релизам сервера 1С:Предприятие 8.3 на одном компьютере

Публикация № 1671080 04.06.22

Системное администрирование - Сервера

WIndows COM+ COM COMConnector соединение сервер два различный разный релиз один компьютер

В публикации рассматривается вопрос о создании двух и более одновременно работающих COM-соединений к различным релизам сервера 1С:Предприятие 8.3 на одном компьютере. Разрабатывалось, тестировалось и работает под платформами 1С 8.3. Но, насколько я углубился в тему, этот алгоритм должен работать и под 8.1, и под 8.2 и в комбинациях.

Публикаций и обсуждений по этому вопросу много, но я не нашел для себя доведенной до финальной точки.

Поэтому решился выложить свою версию.

Просидев ночь, я получил короткий и быстрый алгоритм создания двух и более COM-соединений к серверам 1С:Предприятие разных релизов на одном компьютере, коим и хочу поделиться.

 

Среда разработки, тестирования и использования:

ОС: Windows 11, СУБД: MS SQL 2019, Серверы 1С:Предприятие: релизы 8.3.13.1644 и 8.3.21.1302

ОС: Windows Server 2019, СУБД: MS SQL 2019, Серверы 1С:Предприятие: релизы 8.3.13.1644 и 8.3.21.1302

 

Используемые публикации и обсуждения:

[Шпаргалка] Несколько версий сервера 1С на одном сервере (компьютер)

COM соединения с базами 1С на различных версиях платформы "Без перерегистрации и СМС"

Теперь по порядку.

Собственно началось с установки на Windows Server 2019 второго сервера 1С:Предприятие 8.3.21.1302 для работы с конфигурацией "Бухгалтерия предприятия 3.0". До этого в хлам переписанная конфигурация "Управление торговлей 10.3" работала под сервером 1С:Предприятие 8.3.13.1644. Перевести ее сразу под сервер 1С:Предприятие 8.3.21.1302 не представлялось возможным (требуется доработка конфигурации и продолжительное тестирование), а "Бухгалтерия предприятия 3.0" не работает под сервером 1С:Предприятие 8.3.13.1644. Но нужно как-то организовать обмен между УТ и БП. Поэтому и возникла задача об организации двух ОДНОВРЕМЕННО работающих COM-соединений для серверов 1С:Предприятие 8.3.13.1644 и 1С:Предприятие 8.3.21.1302.

Сначала была установка второго сервера 1С:Предприятие 8.3.21.1302. Останавливаться на этом этапе не буду, он грамотно и подробно описан в [Шпаргалка] Несколько версий сервера 1С на одном сервере (компьютер). Замечу только, что после выполнения этого этапа у меня получилось вот что:

 

Затем начался непосредственно "танец с бубнами" с COM-соединениями. Попробовал использовать Подсистема "Инструменты разработчика" 1С 8. Но так как процесс проходил ночью после рабочего дня, то окончательно разобраться в ней, к сожалению, не получилось. Потом глаз упал на COM соединения с базами 1С на различных версиях платформы "Без перерегистрации и СМС". Вот тут стало интереснее и в результате чтения обсуждения и производства опытов над ОС и 1С и родился алгоритм, который привожу ниже.

ШАГ 1. Запускаем консоль Службы компонентов.

В Windows 11 я не нашел как ее запустить интерактивно, поэтому использовал следующее решение. Запускаем командную строку (CMD) от имени администратора. Выбираем "Файл" -> "Добавить или удалить оснастку" -> "Службы компонентов" -> "Добавить" -> "ОК". Затем "Файл" -> "Сохранить как...". Вводим свое наименование (например, "Службы компонентов") и место сохранения. Таким образом получаем консоль, в которой будем работать дальше.

 

 

ШАГ 2. В ветке "Приложения COM+" создаем 3 приложения : 1СV8, 1CV8_3_13_1644 и 1CV8_3_21_1302, и 2 псевдонима: V83.ComConnector.8.3.13.1644 и V83.ComConnector.8.3.21.1302.

Имена приложениям и псевдонимам для удобства даем в соответствии с релизами серверов 1С:Предприятие.

 

 

Способ активации Серверное приложение, Далее

 

 

Учетная запись Текущий пользователь, Далее

 

 

Далее

 

 

Далее

 

 

Результат

 

 

Добавляем компонент в приложение 1CV8

 

 

При этом выбираем ЛЮБОЙ из нужных нам двух компонентов comcntr.dll

 

 

Далее

 

 

Результат

 

 

Создаем 2 псевдонима: V83.ComConnector.8.3.13.1644 и V83.ComConnector.8.3.21.1302 в соответствующих приложениях

 

 

Результат

 

 

На этом работа с консолью Службы приложений завершена.

В результате созданы два COMConnector'а: V83.COMConnector.8.3.13.1644 и V83.COMConnector.8.3.21.1302.

Но весь процесс еще не завершен.

ШАГ 3. Работаем с реестром Windows.

Теперь нужно привести в соответствие псевдонимы созданных COMConnector'ов с реальными библиотеками comcntr.dll, которые будут подгружаться при вызове конструктора Новый COMОбъект.

Для этого запускаем Win+R - regedit.

Далее описанная операция повторяется для каждого созданного псевдонима.

По Ctrl-F ищем имя псевдонима V83.ComConnector.8.3.13.1644

 

 

Нашли раздел (имя раздела = ID псевдонима)

 

 

В подразделе InprocServer32 в значение (По умолчанию) подставляем полный путь к нужной компоненте

 

 

Практика показала, что эти изменения достаточно внести в ветке HKEY_CLASSES_ROOT\WOW6432Node\CLSID\.

Но для успокоения души можно пройтись дальше поиском (F3) и удостовериться, что имена компонентов COM+ совпадают с папками 1С bin соответствующих версий.

ТЕПЕРЬ ВСЕ, можно работать.

ШАГ 4. Создание и вызов методов компонент в языке 1С.

ПРИМЕР тонкий клиент

&НаКлиенте
Функция ПодключитьCOM()
    результат = Неопределено;
    строкаПодключения = "Srvr=""localhost:1541"";Ref=""ut"";Usr=""администратор"";Pwd=""12345"";";
    Попытка
        соединение = Новый COMОбъект("V83.COMConnector.8.3.13.1644");
        результат = соединение.Connect(строкаПодключения);
        ПоказатьПредупреждение(, "Подключено!");
    Исключение
        Сообщить(ОписаниеОшибки());
        ПоказатьПредупреждение(, "Ошибка подключения!");
    КонецПопытки;
    Возврат результат;
КонецФункции
// Это можно делать и &НаСервере, только смысла в возврате значения нет,
// т.к. он, в отличие от &НаКлиенте, не сохранится для дальнейшего использования.
// Но это уже другая история...

ПРИМЕР толстый клиент

Функция ПодключитьCOM()
    результат = Неопределено;
    строкаПодключения = "Srvr=""localhost:2541"";Ref=""bp"";Usr=""администратор"";Pwd=""12345"";";
    Попытка
        соединение = Новый COMОбъект("V83.COMConnector.8.3.21.1302");
        результат = соединение.Connect(строкаПодключения);
        Предупреждение("Подключено!");
    Исключение
        Сообщить(ОписаниеОшибки());
        Предупреждение("Ошибка подключения!");
    КонецПопытки;
    Возврат результат;
КонецФункции

PS

    ПРЕИМУЩЕСТВА

    1. СКОРОСТЬ И ПРОСТОТА. Все операции можно неторопливо выполнить за 5-10 минут (разброс - это время поиска в реестре Windows на конкретном компьютере). Алгоритм не сложный и доступный для тех, кто сталкивался с подобными проблемами.

    2. СДЕЛАЛ И ЗАБЫЛ. Код строго привязан к компонентам COM+ операционной системы и на него не повлияют ни "случайная" раз- или пере- регистрация COM-компонентов, ни установка нового релиза платформы 1С, ни черт, ни ладан, ни герой... :). Хотя это пока под вопросом из-за непродолжительного срока тестирования и использования. Если же все-таки произошел сбой, то восстановление занимает те же 5 минут, причем не требуется перезапуск клиентских приложений 1С!

    3. ПРАВА. Не требуются полные права администратора операционной системы на выполнение описанных операций. Достаточны доступ к консоли Службы компонентов и реестру WIndows. Если системный администратор не готов предоставить их администратору или программисту 1С, то он способен выполнить эти операции сам за короткое время.

    4. ОПИСАНИЕ. Постарался более-менее полно и наглядно описать алгоритм (не в последнюю очередь для себя, чтобы при необходимости им воспользоваться).

    НЕДОСТАТКИ

    1. Говорят, что при регистрации компонентов указанным способом (посредством DCOM) снижается скорость обработки данных. Мной это еще не тестировалось. Основной целью был стабильный одновременный обмен данными между базами данных приложений, работающих под серверами 1С:Предприятие разных релизов, установленных на одном компьютере.

    2. Малое время использования для набора статистики по стабильности, скорости и т.п., нужно время, будем посмотреть.

    БАЯН

    Как было сказано в начале, уверен, что многие занимались этой проблемой и решили ее. Но мне такое решение, к сожалению, не попалось :(. Вот и решил выложить свое выстраданное. Поэтому убедительна просьба не давать комментарии типа "разуй глаза", "погугли" и т.п. Если есть конкретные замечания или более совершенные или отличные разработки - прошу. Благодарю.

Специальные предложения

Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. tormozit 6729 04.06.22 12:58 Сейчас в теме
Попробовал использовать Подсистема "Инструменты разработчика" 1С 8... разобраться в ней, к сожалению, не получилось

Там это по задумке делается за 1 минуту. В каком месте не получилось? Кстати ты мог бы задать вопрос в телеграм чате тех. поддержки https://www.hostedredmine.com/issues/922012
nyam-nyam; +1 Ответить
2. dimaster 39 25.07.22 20:53 Сейчас в теме
(1) тож решал Вашей подсистемой. все ок
Оставьте свое сообщение

См. также

Подбираем сервер для 1C:ERP Промо

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

На Infostart Meetup Ekaterinburg ведущий разработчик 1С в компании ФТО Виталий Онянов рассказал, как подобрать сервер для 1С:ERP и на какие показатели ориентироваться, чтобы оборудование для высоконагруженной системы оправдало вложения.

26.03.2021    20978    Tavalik    74    

Разворачиваем сервер 1С:Предприятие 8 (8.3.20.2076) и сервер БД Postgres Pro(13) на Windows Subsystem for Linux (WSL 2.0+Ubuntu 20.04)

Сервера Платформа 1С v8.3 Россия Бесплатно (free)

Минимально достаточный перечень команд для разворачивания среды.

13.11.2022    1035    dvsidelnikov    21    

Ферма ОДИНа или как управлять множеством Серверов 1С: Предприятие из одной точки

Мониторинг Сервера Платформа 1С v8.3 Бесплатно (free)

У Вас много серверов приложений 1С Предприятие разных версий и их надо мониторить и администрировать. Новое приложение для управления фермой ОДИНа как раз для тебя.

26.08.2021    1898    khorevaa    8    

Как добыть последнюю версию SQL Server 2012 Native Client

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

Краткое руководство администраторам 1С по получению свежей версии SQL Server 2012 Native Client, необходимого для работы сервера 1С.

13.05.2021    14622    tedkuban    3    

Моя война с Adodb.connection "Microsoft.Jet.OLEDB.4.0" на 64-х битных серверных ОС (86х) Промо

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

На тонком клиенте в управляемом приложении появилась потребность работы с Adodb.Connection. В моем случае это был драйвер "Microsoft.Jet.OLEDB.4.0". В файловом варианте все взлетело без проблем... А вот в серверном начались проблемы. Решениям этих проблем и посвящается данная статья.

20.02.2013    32274    Alexander.Shvets    11    

Настройка сборки данных в Performance Monitor Windows Server. Рецепты от Капитана

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

Каждый опытный сисадмин знает, что лучший показатель ухудшения быстродействия 1С, это главный бухгалтер, движущийся в сторону ИТ отдела со скоростью, превышающей 1.1 м/с. Но только мудрейшие из них настраивают сбор счетчиков, чтобы эта встреча не застала их врасплох. Об этом и поговорим под катом...

07.05.2021    6192    capitan    21    

Использование полного DNS имени при обращении к серверу 1С через OpenVPN

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

В статье опишу настройки для работы клиента с сервером 1С по полному DNS имени. Приведу пример проброса доменной зоны используя OpenVPN.

03.11.2020    4354    malikov_pro    16    

Простой TCP сервер с обработкой событий на стороне 1С

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

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

05.12.2012    33212    VoDo    7