Skip to main content

SSL — Hostname mismatch, certificate is not valid for '...'


title: SSL — Hostname mismatch, certificate is not valid for '...' slug: ts-ssl-hostname-mismatch tags: [ssl, hostname mismatch, сертификат, синхронизация, CUPS] domain: Troubleshooting type: Troubleshooting audience: partner-engineer product_versions: "4.x" status: ready related_components: [Мониторинг, ПринтМенеджер, Балансировщик] related_pages:

  • trebovaniya-k-ssl-sertifikatam
  • kak-obnovit-printum

SSL — Hostname mismatch, certificate is not valid for '...'

Симптомы

В логах ПринтМенеджер или при установке:

[SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed:
Hostname mismatch, certificate is not valid for '<адрес>'

Синхронизация Мониторинг–ПринтМенеджер не работает. CUPS не создаёт принтеры. Встроенное приложение не подключается к серверу.


Причина

Адрес, по которому компонент обращается к серверу, не совпадает с CN или Subject Alternative Name (SAN) сертификата.

Типичные ситуации:

  • Система установлена по hostname, а сертификат выпущен на IP (или наоборот).
  • После обновления изменился адрес сервера, сертификат остался старый.
  • При установке с балансировщиком каждому серверу нужен собственный сертификат — использовался один общий.

Диагностика

Проверить, для какого адреса выпущен сертификат:

openssl s_client -connect <адрес_сервера>:<порт> </dev/null 2>/dev/null \
  | openssl x509 -noout -subject -ext subjectAltName

Сравнить с адресом, по которому идёт обращение:

# Для ПМ — адрес М в .env
grep MONITORING_ADDRESS /opt/printmanager/.env

# Для клиента ПМ на Linux
grep server_url /opt/printum/printmanager_client/settings.yml

Если адреса не совпадают — причина найдена.


Решение

Автоматические сертификаты

Переустановка без SSL-параметров пересоздаёт сертификаты автоматически под текущий адрес:

# М
sudo curl -L https://s3.printum.io/box/monitoring/install.sh | sudo -E bash

# ПМ
sudo curl -L https://s3.printum.io/distrib/printum-printmanager/install.sh | sudo -E bash

Собственные сертификаты

Перевыпустить сертификат для актуального адреса сервера. CN и SAN должны содержать адрес, по которому компонент обращается к серверу. Затем обновить с новыми файлами:

sudo curl -L https://s3.printum.io/box/monitoring/install.sh | \
  sudo -E SSL_CERT=/path/cert.crt \
       SSL_KEY=/path/cert.key \
       SSL_CERT_CA=/path/ca.crt bash -s agent

Балансировщик

При установке с балансировщиком у каждого сервера должен быть собственный сертификат, выпущенный для его адреса. Один сертификат на все серверы не подходит.


Как проверить результат

cd /opt/printmanager
sudo docker-compose logs printmanager-celery-print-queue --tail=50 | grep -i ssl

Ошибок SSL нет. Синхронизация Мониторинг–ПринтМенеджер завершается успешно.


Когда эскалировать

  • После перевыпуска сертификата ошибка сохраняется.
  • PKI управляется заказчиком — требуется его участие.
  • Нет возможности выпустить сертификат для нужного hostname/IP.

Связанные страницы