Сертификат агента кукол подтвердил ошибку
У меня настроен Puppet Master/Agent, и я успешно подписал сертификат для агента на master. Тем не менее, когда я бегу puppet agent --test
Я получаю сбой, который выглядит так:
Warning: Unable to fetch my node definition, but the agent run will continue:
Warning: SSL_connect returned=1 errno=0 state=SSLv3 read server certificate B: certificate verify failed: [certificate signature failure for /CN=hostname.domain.com]
Info: Retrieving plugin
Error: /File[/var/lib/puppet/lib]: Failed to generate additional resources using 'eval_generate: SSL_connect returned=1 errno=0 state=SSLv3 read server certificate B: certificate verify failed: [certificate signature failure for /CN=hostname.domain.com]
Error: /File[/var/lib/puppet/lib]: Could not evaluate: SSL_connect returned=1 errno=0 state=SSLv3 read server certificate B: certificate verify failed: [certificate signature failure for /CN=hostname.domain.com] Could not retrieve file metadata for puppet://hostname.domain.com/plugins: SSL_connect returned=1 errno=0 state=SSLv3 read server certificate B: certificate verify failed: [certificate signature failure for /CN=hostname.domain.com]
Error: Could not retrieve catalog from remote server: SSL_connect returned=1 errno=0 state=SSLv3 read server certificate B: certificate verify failed: [certificate signature failure for /CN=hostname.domain.com]
Warning: Not using cache on failed catalog
Error: Could not retrieve catalog; skipping run
Error: Could not send report: SSL_connect returned=1 errno=0 state=SSLv3 read server certificate B: certificate verify failed: [certificate signature failure for /CN=hostname.domain.com]
hostname.domain.com
хозяин
Как это исправить? Я убедился, что оба часа находятся в правильное время в одном часовом поясе, я удалил все в агенте /var/lib/puppet/ssl
каталог и подал в отставку, я не знаю, что еще делать.
2 ответа
Повторно создайте полную настройку сертификата клиента. Это всегда исправляло любые проблемы с сертификатом, с которыми мы сталкивались в прошлом. В следующей инструкции предполагается, что имя хоста вашего агента - agenthost.hostname.com
На клиенте удалите все сохраненные сертификаты, включая CA:
find /var/lib/puppet/ssl -name '*.pem' -delete
На главном компьютере удалите все ожидающие CSR или старые клиентские сертификаты для этого клиента:
find /var/lib/puppet/ssl -name agenthost.domain.com.pem -delete
Затем на клиенте переподключитесь к мастеру и отправьте CSR:
puppet agent -t --waitforcert=60
и когда он ожидает (если вы не включили автоподпись), то на мастере утверждают CSR, поэтому новый клиентский сертификат отправляется обратно:
puppet cert sign agenthost.domain.com
Это должно заставить агента повторно загрузить марионеточные сертификаты CA и повторно подать заявку на собственный сертификат.
Мы должны были использовать эту процедуру в прошлом, когда мы меняли марионеточные серверы и сертификаты CA менялись, или когда мы перестраивали хост с тем же именем хоста.
Убедитесь, что ваш агент знает свое полное имя хоста; используйте команду 'hostname', чтобы убедиться, что это именно то, что вы ожидаете.
У меня похожая проблема. Я создал бродячую среду с одним марионеткой и несколькими клиентами. Проблема в том, что когда я уничтожаю и создаю хозяина кукол, клиенты обнаруживают нового хозяина кукол как самозванца.
Удаление /etc/puppet/ssl
на клиенте решает проблему.
Помните, что ваша конфигурация ssl будет кэширована, поэтому требуется перезапуск мастера Puppet, если вы решите также удалить свой /etc/puppet/ssl
на этом хосте:
sudo /etc/init.d/puppetmaster restart