Исходный код вики Установка SQL REST Proxy сервиса
Версия 7.2 от Всезнайка PROSTO:СКУД на 2026/03/08 15:53
Последние авторы
| author | version | line-number | content |
|---|---|---|---|
| 1 | **SQL REST Proxy** — лёгкий REST-сервис на Python, разработанный как замена прямым вызовам SQL через ADODB.Connection в конфигурациях 1С, работающих на Linux. Поскольку COM-объекты и нативные ODBC-драйверы недоступны на Linux-платформе 1С:Предприятие, этот сервис позволяет выполнять произвольные SQL-запросы к внешним базам данных через стандартный HTTP-вызов из встроенного языка 1С. | ||
| 2 | |||
| 3 | **Поддерживаемые СУБД** | ||
| 4 | |||
| 5 | |=СУБД |=Драйвер |=Порт по умолчанию | ||
| 6 | |PostgreSQL|psycopg2 |5432 | ||
| 7 | |Microsoft SQL Server|pymssql|1433 | ||
| 8 | |MySQL |PyMySQL |3306 | ||
| 9 | |||
| 10 | |||
| 11 | |||
| 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 | **Установка** | ||
| 24 | Для установки нужно скачать проект с github либо развернуть из архива (доступного для скачивания по ссылке): | ||
| 25 | |||
| 26 | ># git clone https://prosto-skud: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@github.com/prosto-skud/p-skud-sql-proxy-service.git | ||
| 27 | |||
| 28 | **Запуск** | ||
| 29 | Переходим в директорию сервиса | ||
| 30 | |||
| 31 | ># cd p-skud-sql-proxy-service | ||
| 32 | |||
| 33 | Генерируем сертификаты | ||
| 34 | |||
| 35 | ># bash generate_certs.sh | ||
| 36 | |||
| 37 | Копируем .env | ||
| 38 | |||
| 39 | ># cp .env.example .env | ||
| 40 | |||
| 41 | И если требуется настраиваем под ваш контур .env | ||
| 42 | |||
| 43 | ># nano .env | ||
| 44 | |||
| 45 | В файле можно изменить: | ||
| 46 | |||
| 47 | ># API Key для аутентификации запросов | ||
| 48 | ># API_KEY=skud_proxy_19e1d5c545b55bdb3459281bd3a1c06a29c467c5645b3ceb748bb2589a5e0d46 | ||
| 49 | |||
| 50 | ># И порты работы Сервиса | ||
| 51 | ># SERVICE_PORT=8443 | ||
| 52 | ># PROMETHEUS_PORT=9090 | ||
| 53 | |||
| 54 | Поднимаем все сервисы из docker-compose.yml | ||
| 55 | |||
| 56 | ># docker compose up -d | ||
| 57 | |||
| 58 | Проверка | ||
| 59 | |||
| 60 | ># curl -k https://<server>:8443/health |