
エージェントからのリクエストの中には、ホスト名が間違っているものがいくつかあります。これを修正しましたが、ホスト名が間違っている未処理のリクエストがまだ残っています。
私は試した:
$puppet cert list
"wrong.host.name" (SHA256) 8E:...:51
$ puppet cert revoke wrong.host.name
Error: Could not find a serial number for wrong.host.name
$ puppet cert clean wrong.host.name
Error: Could not find a serial number for wrong.host.name
それらを取り除く適切な方法は何ですか?
答え1
使用ca
はより適切に機能し、とは異なり、1 つの手順で証明書を削除できますcert
。重要なのは、無効な証明書に一時的に署名する必要がないことです。
$ puppet ca destroy wrong.host.name
Notice: Removing file Puppet::SSL::CertificateRequest wrong.host.name at '/var/lib/puppet/ssl/ca/requests/wrong.host.name.pem'
Deleted for wrong.host.name: Puppet::SSL::CertificateRequest
コマンドpuppet ca
最近廃止されましたいつかはなくなるかもしれないが、同等のコマンドはない。バグファイルに、このコマンドを代替なしで削除するのは少しばかげていると思う場合は、投票することができます。
答え2
考えられる解決策1:
パペット マスターでを使用するのがpuppet cert clean
適切な方法です。ただし、エラーが発生しているため、証明書のインベントリが間違っている可能性があります。
再インベントリを実行してからクリーンアップを実行してみてください。
$ puppet cert reinventory
$ puppet cert clean --all
注: この例では--all
フラグを使用していますが、これにより、署名済みおよび未署名のすべての証明書がクリアされます。また、 を実行する前に Puppet マスターを停止する必要があることに注意してくださいreinventory
。
ソース:http://docs.puppetlabs.com/references/3.6.2/man/cert.html
考えられる解決策2:
$ puppet cert sign wrong.host.name
Notice: Signed certificate request for wrong.host.name
Notice: Removing file Puppet::SSL::CertificateRequest wrong.host.name at '/var/lib/puppet/ssl/ca/requests/wrong.host.name.pem'
$ puppet cert clean wrong.host.name
Notice: Revoked certificate with serial 87
Notice: Removing file Puppet::SSL::Certificate wrong.host.name at '/var/lib/puppet/ssl/ca/signed/wrong.host.name.pem'
Notice: Removing file Puppet::SSL::Certificate wrong.host.name at '/var/lib/puppet/ssl/certs/wrong.host.name.pem'
考えられる解決策3:
最初: サーバー上
$ puppet cert --revoke wrong.host.name
$ puppet cert --clean wrong.host.name
2番目: クライアント側
$ rm -rf /usr/lib/puppet/ssl
$ puppet agent --server [puppetmaster domain name] --waitforcert 60
3番目: サーバー上(必要に応じて調整)
$ puppet cert --list (you should see your host)
$ puppet cert --sign wrong.host.name
また、クライアントが [puppetmaster ドメイン名] にアクセスできるかどうかを再確認してください。
答え3
私がやった方法はこれです
[root@puppetmc ca]# puppet cert clean sparrow.home
Error: Could not find a serial number for sparrow.home
[root@puppetmc ca]# cat inventory.txt
0x0002 2015-05-17T06:33:29GMT 2020-05-16T06:33:29GMT /CN=puppetmc.home
0x0003 2015-05-17T23:25:33GMT 2020-05-16T23:25:33GMT /CN=sparrow.rospop.com
0x0004 2015-05-18T00:53:18GMT 2020-05-17T00:53:18GMT /CN=puppetmc.home
0x0005 2015-05-18T02:18:12GMT 2020-05-17T02:18:12GMT /CN=sparrow.rospop.com
[root@puppetmc ca]# vi inventory.txt
inventory.txt に以下の行を追加しました:
0x0001 2015-05-17T06:33:29GMT 2020-05-16T06:33:29GMT /CN=sparrow.home
実行
[root@puppetmc ca]# puppet cert clean sparrow.home
Notice: Revoked certificate with serial 1
Notice: Removing file Puppet::SSL::CertificateRequest sparrow.home at '/var/lib/puppet/ssl/ca/requests/sparrow.home.pem'
Vince Bhebhe