2011-12-27 4 views
0

Я пытаюсь настроить кукловодов и кукольных клиентов с помощью Ubuntu 11.10 EC2 экземпляров (ami-a562a9cc). Я включил автоматическое подписание сертификата. Но всякий раз, когда я выполняю команду из кукольного клиента:EC2 Ubuntu 11.10 Кукольное имя хоста имя ошибка mistmatch

#puppet агент --server кукольного --waitforcert 60 --test

сертификатов подписал контракт, но он выдает ошибку и не запускается файл каталог.

Сообщение об ошибке:

ERR: Не удалось получить каталог с удаленного сервера: имя хоста не совпадает с сертификатом сервера предупреждение: Не использование кэша при неудачном каталога ERR: Не удалось получить каталог; пропуская пробег err: Не удалось отправить отчет: имя хоста не совпало с сертификатом сервера

Применение файла манифеста на PuppetMaster отлично работает, но не работает на кукольных игроках.

Я уже установил кукольную среду на Amazon Linux & Centos, и это сработало на них отлично. Но я столкнулся эти вопросы для Ubuntu 11.10

Благодарности Sanket Данги

ответ

6

Кукольный использует стандартные x.509 SSL сертификаты для общения. Это те же сертификаты, которые используются в HTTPS, поэтому вы можете думать о них, используя одну и ту же ментальную модель.

Эта проблема почти всегда возникает из-за ситуации, когда марионетный агент использует имя, не указанное в теме, или поле x.509 alt названия сертификата мастера кукол.

Для решения этой проблемы, пожалуйста, спросите себя: «Используется ли агент, чтобы связаться с мастером, указанным в сертификате мастера?»

Чтобы ответить на этот вопрос, вы должны определить имя, используемое агентом для обращения к мастеру. В вашем примере, поскольку вы указали опцию --server puppet, используется кукольное название. Если вы работаете с развертыванием кукол вы сами не настройки, вы можете найти настроенное имя с помощью команды puppet agent --configprint server, который должен напечатать назад что-то вроде этого:

% puppet agent --configprint server 
puppetmaster.acme.com 

Теперь, когда мы знаем, что агент использует имя «puppetmaster.acme.com», чтобы связаться с мастером, следующий вопрос: «Is puppetmaster.acme.com» в сертификате SSL мастера.

Чтобы ответить на этот вопрос, перейдите к Мастеру марионеток и проверьте, что SSL-сертификат x.509 используется. Это можно сделать с помощью следующей команды. Эта команда использует опцию --configprint, чтобы узнать имя сертификата, используемое Мастером Марионеток. Обычно это имя хоста. Команда puppet cert print распечатывает сертификат в удобной для пользователя форме и точно так же, как и команда openssl x509 -text -noout -in ..., с которой вы уже знакомы.

[email protected]:~# puppet cert print $(puppet master --configprint certname) 
Certificate: 
Data: 
    Version: 3 (0x2) 
    Serial Number: 2 (0x2) 
    Signature Algorithm: sha1WithRSAEncryption 
    Issuer: CN=Puppet CA generated on pe-centos6.puppetlabs.vm at Tue Jan 3 14:54:26 PST 2012 
    Validity 
     Not Before: Jan 2 22:55:16 2012 GMT 
     Not After : Jan 1 22:55:16 2017 GMT 
    Subject: CN=pe-centos6.localdomain 
    Subject Public Key Info: 
     Public Key Algorithm: rsaEncryption 
      Public-Key: (1024 bit) 
      Modulus: 
       00:d2:51:86:31:b0:d8:da:80:1c:b9:e3:74:6b:c0: 
       2a:3c:b2:1a:dd:2b:1e:14:1d:53:b3:de:06:78:a7: 
       c2:bb:ad:bc:7e:91:60:01:d5:83:a7:14:c5:55:ea: 
       09:05:4e:c8:6e:83:93:a2:fb:e6:59:11:c1:05:88: 
       08:53:85:4f:6b:ef:a4:d6:14:6c:d8:56:e9:7c:79: 
       30:97:3a:fc:71:26:20:c7:15:5c:1b:d7:9d:e9:35: 
       08:a8:e2:5d:6c:a3:0d:0b:0e:90:dd:51:15:14:d6: 
       3f:6e:ab:2d:c8:0d:7f:4a:69:a7:7e:17:a2:d5:59: 
       be:c4:ba:a8:f7:54:db:b5:5f 
      Exponent: 65537 (0x10001) 
    X509v3 extensions: 
     X509v3 Subject Alternative Name: 
      DNS:pe-centos6.localdomain, DNS:puppet 
     X509v3 Basic Constraints: critical 
      CA:FALSE 
     Netscape Comment: 
      Puppet Ruby/OpenSSL Internal Certificate 
     X509v3 Key Usage: critical 
      Digital Signature, Key Encipherment 
     X509v3 Subject Key Identifier: 
      88:C4:17:D1:16:FA:0E:F0:E9:AC:00:FC:02:E0:81:53:53:8F:F4:71 
     X509v3 Extended Key Usage: critical 
      TLS Web Server Authentication, TLS Web Client Authentication 
Signature Algorithm: sha1WithRSAEncryption 
    a2:dc:18:b4:7d:56:4a:5b:22:fc:72:7e:37:a9:cd:05:5b:39: 
    63:92:75:0b:1f:05:f7:60:2d:85:ea:79:b5:55:ba:b4:e4:6f: 
    10:00:3b:e2:f0:e2:89:ac:82:5f:2e:c5:45:20:33:75:35:a6: 
    51:3d:fd:a1:7f:38:6f:9c:71:6f:5f:a4:8d:7d:a7:cc:4e:ed: 
    f2:46:9c:a4:b1:4f:83:19:e1:57:83:07:ac:54:ce:84:af:48: 
    7f:ca:52:f2:2b:0f:b1:5a:02:aa:4f:7e:f1:e2:12:77:d2:2f: 
    6a:b5:92:61:69:1e:c6:10:3e:8e:c3:b9:0d:a7:2a:8b:ff:17: 
    bc:81 

Фокус на двух полях имени Subject: и X509v3 Subject Alternative Name: Если имя найдено в первой стадии (puppetmaster.acme.com) не указана ни в одном из этих двух полей, то вы будете уверены, что получить hostname was not match with the server certificate warning вы получили ,

Для решения проблемы просто используйте puppet agent --server <hostname> где <hostname> что-то перечисленное в сертификате используется мастером.

Вам не нужно повторно выдавать сертификаты для решения этой проблемы.

Надеюсь, это поможет.

+1

Большое спасибо за информацию :) Для экземпляров ubuntu я использовал экземпляр экземпляра EC2 вместо марионетки, и он работал как шарм :) –

 Смежные вопросы

  • Нет связанных вопросов^_^