Требования к SSL-сертификатам для Printum
title: Требования к SSL-сертификатам для Printum slug: trebovaniya-k-ssl-sertifikatam tags: [ssl, сертификат, tls, SAN, требования, установка] domain: Security type: Reference audience: partner-engineer product_versions: "4.x" status: ready related_components: [Мониторинг, ПринтМенеджер, Балансировщик] related_pages:
- kak-obnovit-printum
- ts-ssl-hostname-mismatch
- ts-ssl-self-signed-in-chain
- ts-ssl-unable-to-get-local-issuer
Требования к SSL-сертификатам для Printum
Когда использовать
Перед выпуском собственных сертификатов для установки или обновления Printum.
Состав сертификатов
Для базовой (singlenode) схемы нужны три файла:
| Файл | Описание |
|---|---|
ca.crt |
Корневой сертификат (CA) |
server.crt |
Сертификат сервера |
server.key |
Закрытый ключ сертификата сервера |
Если используется промежуточный CA — он тоже должен быть передан отдельным файлом.
Для схемы с балансировщиком — отдельный сертификат и ключ для каждого сервера (HAProxy, М,Мониторинг, каждый ПМ,ПринтМенеджер, сервер БД+NFS).
Привязка сертификата
- Установка по IP: сертификат выпускается на IP-адрес сервера.
- Установка по hostname: сертификат выпускается на hostname (FQDN).
Нельзя смешивать: если система установлена по hostname, а сертификат выпущен на IP — будет ошибка Hostname mismatch.
Обязательные атрибуты
SSL-сертификат сервера:
- X509v3 Extended Key Usage:
TLS Web Server Authentication,TLS Web Client Authentication - X509v3 Subject Alternative Name (SAN) — обязателен. Должен содержать все адреса сервера:
DNS:server1.example.com
DNS:server1
IP:10.0.0.1
Без SAN будет ошибка unable to get local issuer certificate.
Корневой сертификат (CA):
- X509v3 Key Usage:
Digital Signature,Certificate Sign
Формат
- Данные в сертификатах — в незашифрованном текстовом виде, кодировка UTF-8.
- Поддерживаемые расширения:
.cer,.crt,.pem(для сертификатов),.key(для ключа). - Корневой сертификат — отдельный файл. Нельзя включать его содержимое в
server.crt.
Типовые ошибки и их причины
| Ошибка в логах | Причина |
|---|---|
Hostname mismatch |
Адрес сервера не совпадает с CN или SAN сертификата |
self signed certificate in certificate chain |
Содержимое CA включено в server.crt |
unable to get local issuer certificate |
Отсутствует поле SAN в сертификате |
Подробнее — в соответствующих troubleshooting-статьях (ссылки ниже).
Схема с балансировщиком HAProxy
Сертификат и ключ к нему должны быть предоставлены отдельно для каждого сервера. Корневой сертификат остаётся общим.
Пример комплекта для развёртывания HAProxy с серверами:
Необходимые файлы:
.cer/.crt/.pem) — один общий для всех серверов.
Сертификат сервера и ключ — для каждого из 6 серверов отдельно.
Примечание: Для филиальных ПринтМенеджеров — обязательно собственные сертификаты.
Альтернатива: автоматические сертификаты
Если собственные сертификаты недоступны или не нужны — использовать автоматические. Система генерирует их при установке без дополнительных параметров. Подходят для большинства сценариев, браузеры будут показывать предупреждение, но функциональность не страдает.