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

Редактировал(а) Всезнайка PROSTO:СКУД 2026/03/10 04: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 **Поддерживаемые СУБД**
4
Всезнайка PROSTO:СКУД 7.1 5 |=СУБД |=Драйвер |=Порт по умолчанию
6 |PostgreSQL|psycopg2 |5432
7 |Microsoft SQL Server|pymssql|1433
8 |MySQL |PyMySQL |3306
9
10
11
Всезнайка PROSTO:СКУД 2.1 12 **Режим развёртывания**
13 Сервис запускается в Docker-контейнере и не требует установки каких-либо драйверов в хост-систему. Управление через docker-compose.
14
15 **Безопасность**
16 - Аутентификация по API-ключу (X-API-Key заголовок)
17 - HTTPS/TLS с поддержкой собственного сертификата
18 - Параметризованные запросы исключают SQL-инъекции
19
20 **Мониторинг**
21 Эндпоинт /metrics предоставляет метрики в формате Prometheus. Готовый конфиг prometheus.yml для сбора метрик включён в поставку. Эндпоинт /pools/stats возвращает детальную статистику по активным пулам соединений.
22
23 **Установка**
Всезнайка PROSTO:СКУД 9.1 24 Для установки нужно скачать проект с github либо развернуть из архива (p-skud-sql-proxy-service-main.zip находится в каталоге "Модули и ODBC-драйверы" из поставки расширения):
Всезнайка PROSTO:СКУД 7.1 25
Всезнайка PROSTO:СКУД 8.1 26 ># git clone https://prosto-skud:API_КЛЮЧ_ДЛЯ_ДОСТУПА_К_РЕПОЗИТОРИЮ@github.com/prosto-skud/p-skud-sql-proxy-service.git
Всезнайка PROSTO:СКУД 2.1 27
28 **Запуск**
29 Переходим в директорию сервиса
30
Всезнайка PROSTO:СКУД 3.1 31 ># cd p-skud-sql-proxy-service
Всезнайка PROSTO:СКУД 1.1 32
Всезнайка PROSTO:СКУД 3.1 33 Генерируем сертификаты
Всезнайка PROSTO:СКУД 4.1 34
Всезнайка PROSTO:СКУД 3.1 35 ># bash generate_certs.sh
Всезнайка PROSTO:СКУД 1.1 36
Всезнайка PROSTO:СКУД 2.1 37 Копируем .env
Всезнайка PROSTO:СКУД 4.1 38
Всезнайка PROSTO:СКУД 3.1 39 ># cp .env.example .env
40
Всезнайка PROSTO:СКУД 2.1 41 И если требуется настраиваем под ваш контур .env
Всезнайка PROSTO:СКУД 4.1 42
Всезнайка PROSTO:СКУД 3.1 43 ># nano .env
44
Всезнайка PROSTO:СКУД 1.1 45 В файле можно изменить:
Всезнайка PROSTO:СКУД 4.1 46
Всезнайка PROSTO:СКУД 6.1 47 ># API Key для аутентификации запросов
Всезнайка PROSTO:СКУД 3.1 48 ># API_KEY=skud_proxy_19e1d5c545b55bdb3459281bd3a1c06a29c467c5645b3ceb748bb2589a5e0d46
Всезнайка PROSTO:СКУД 2.1 49
Всезнайка PROSTO:СКУД 6.1 50 ># И порты работы Сервиса
Всезнайка PROSTO:СКУД 3.1 51 ># SERVICE_PORT=8443
52 ># PROMETHEUS_PORT=9090
Всезнайка PROSTO:СКУД 1.1 53
Всезнайка PROSTO:СКУД 2.1 54 Поднимаем все сервисы из docker-compose.yml
Всезнайка PROSTO:СКУД 4.1 55
Всезнайка PROSTO:СКУД 3.1 56 ># docker compose up -d
Всезнайка PROSTO:СКУД 2.1 57
58 Проверка
Всезнайка PROSTO:СКУД 4.1 59
Всезнайка PROSTO:СКУД 3.1 60 ># curl -k https://<server>:8443/health