Исходный код вики Установка SQL REST Proxy сервиса

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

Скрыть последних авторов
Всезнайка PROSTO:СКУД 2.1 1 **SQL REST Proxy** — лёгкий REST-сервис на Python, разработанный как замена прямым вызовам SQL через ADODB.Connection в конфигурациях 1С, работающих на Linux. Поскольку COM-объекты и нативные ODBC-драйверы недоступны на Linux-платформе 1С:Предприятие, этот сервис позволяет выполнять произвольные SQL-запросы к внешним базам данных через стандартный HTTP-вызов из встроенного языка 1С.
Всезнайка PROSTO:СКУД 1.1 2
Всезнайка PROSTO:СКУД 2.1 3 **Поддерживаемые СУБД**
Всезнайка PROSTO:СКУД 3.1 4 СУБД Драйвер Порт по умолчанию
5 PostgreSQL psycopg2 5432
6 Microsoft SQL Server pymssql 1433
7 MySQL PyMySQL 3306
Всезнайка PROSTO:СКУД 2.1 8
9 **Режим развёртывания**
10 Сервис запускается в Docker-контейнере и не требует установки каких-либо драйверов в хост-систему. Управление через docker-compose.
11
12 **Безопасность**
13 - Аутентификация по API-ключу (X-API-Key заголовок)
14 - HTTPS/TLS с поддержкой собственного сертификата
15 - Параметризованные запросы исключают SQL-инъекции
16
17 **Мониторинг**
18 Эндпоинт /metrics предоставляет метрики в формате Prometheus. Готовый конфиг prometheus.yml для сбора метрик включён в поставку. Эндпоинт /pools/stats возвращает детальную статистику по активным пулам соединений.
19
20 **Установка**
21 Для установки нужно скачать проект с github либо развернуть из архива (доступного для скачивания по ссылке):
22 git clone https://prosto-skud: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@github.com/prosto-skud/p-skud-sql-proxy-service.git
23
24 **Запуск**
25 Переходим в директорию сервиса
26
Всезнайка PROSTO:СКУД 3.1 27 ># cd p-skud-sql-proxy-service
Всезнайка PROSTO:СКУД 1.1 28
Всезнайка PROSTO:СКУД 3.1 29 Генерируем сертификаты
30 ># bash generate_certs.sh
Всезнайка PROSTO:СКУД 1.1 31
Всезнайка PROSTO:СКУД 2.1 32 Копируем .env
Всезнайка PROSTO:СКУД 3.1 33 ># cp .env.example .env
34
Всезнайка PROSTO:СКУД 2.1 35 И если требуется настраиваем под ваш контур .env
Всезнайка PROSTO:СКУД 3.1 36 ># nano .env
37
Всезнайка PROSTO:СКУД 1.1 38 В файле можно изменить:
Всезнайка PROSTO:СКУД 3.1 39 ># # API Key для аутентификации запросов
40 ># API_KEY=skud_proxy_19e1d5c545b55bdb3459281bd3a1c06a29c467c5645b3ceb748bb2589a5e0d46
Всезнайка PROSTO:СКУД 2.1 41
Всезнайка PROSTO:СКУД 3.1 42 ># # И порты работы Сервиса
43 ># SERVICE_PORT=8443
44 ># PROMETHEUS_PORT=9090
Всезнайка PROSTO:СКУД 1.1 45
Всезнайка PROSTO:СКУД 2.1 46 Поднимаем все сервисы из docker-compose.yml
Всезнайка PROSTO:СКУД 3.1 47 ># docker compose up -d
Всезнайка PROSTO:СКУД 2.1 48
49 Проверка
Всезнайка PROSTO:СКУД 3.1 50 ># curl -k https://<server>:8443/health