Установка SQL REST Proxy сервиса

Версия 5.1 от Всезнайка PROSTO:СКУД на 2026/03/08 15:50

SQL REST Proxy — лёгкий REST-сервис на Python, разработанный как замена прямым вызовам SQL через ADODB.Connection в конфигурациях 1С, работающих на Linux. Поскольку COM-объекты и нативные ODBC-драйверы недоступны на Linux-платформе 1С:Предприятие, этот сервис позволяет выполнять произвольные SQL-запросы к внешним базам данных через стандартный HTTP-вызов из встроенного языка 1С.

Поддерживаемые СУБД
СУБД     Драйвер               Порт по умолчанию
PostgreSQL psycopg2           5432
Microsoft   SQL Server pymssql   1433
MySQL     PyMySQL               3306

Режим развёртывания
Сервис запускается в Docker-контейнере и не требует установки каких-либо драйверов в хост-систему. Управление через docker-compose.

Безопасность
- Аутентификация по API-ключу (X-API-Key заголовок)
- HTTPS/TLS с поддержкой собственного сертификата
- Параметризованные запросы исключают SQL-инъекции

Мониторинг
Эндпоинт /metrics предоставляет метрики в формате Prometheus. Готовый конфиг prometheus.yml для сбора метрик включён в поставку. Эндпоинт /pools/stats возвращает детальную статистику по активным пулам соединений.

Установка
Для установки нужно скачать проект с github либо развернуть из архива (доступного для скачивания по ссылке):

# git clone https://prosto-skud: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@github.com/prosto-skud/p-skud-sql-proxy-service.git

Запуск
Переходим в директорию сервиса

# cd p-skud-sql-proxy-service

Генерируем сертификаты

# bash generate_certs.sh

Копируем .env

# cp .env.example .env

И если требуется настраиваем под ваш контур .env

# nano .env

В файле можно изменить:

# # API Key для аутентификации запросов
# API_KEY=skud_proxy_19e1d5c545b55bdb3459281bd3a1c06a29c467c5645b3ceb748bb2589a5e0d46

# # И порты работы Сервиса
# SERVICE_PORT=8443
# PROMETHEUS_PORT=9090

Поднимаем все сервисы из docker-compose.yml

# docker compose up -d

Проверка

# curl -k https://<server>:8443/health