外部 Platform Services Controller のある環境で、外部ソリューションに対するvCenter Server または Platform Services Controller の証明書の検証エラーメッセージが発生する
search cancel

外部 Platform Services Controller のある環境で、外部ソリューションに対するvCenter Server または Platform Services Controller の証明書の検証エラーメッセージが発生する

book

Article ID: 324483

calendar_today

Updated On: 04-11-2024

Products

VMware vCenter Server

Issue/Introduction

免責事項:これは英文の記事「vCenter Server or Platform Services Controller certificate validation error messages for external solutions in environments with a External Platform Services Controller (2121701)」の日本語訳です。記事はベストエフォートで翻訳を進めているため、ローカライズ化コンテンツは最新情報ではない可能性があります。最新情報は英語版の記事で参照してください。


 

VMware vCenter Site Recovery Manager、VMware vSphere Replication、または VMware vCenter Support Assistant などの一部のソリューションは、ソリューションの証明書を管理する関連する vCenter Server システムまたは Platform Services Controller とは異なるマシンに常にインストールされます。
 
外部 Platform Services Controller のある環境で、vCenter Server システムまたは Platform Services Controller のマシン SSL 証明書を置き換える場合は、ソリューションが vCenter Server に接続を試みたときに接続エラーが発生します。この理由は、vCenter Server および Platform Services Controller は新しい証明書を使用しますが、VMware Lookup Service に登録された対応するサービス登録情報が更新されないためです。ソリューションが vCenter Server または Platform Services Controller に接続するとき、ソリューションはサービス URL および sslTrust 文字列を含むサービス登録情報を参照します。デフォルトの場合、sslTrust 文字列は、証明書を正常に置き換えることができてもBase 64 エンコードされた古い証明書のままです。
 
この KB 記事では、外部 Platform Services Controller のある環境での問題を解決する方法について説明します。
警告(vSphere 6.0 のみ):

VC/PSC の登録が新しい ssltrust へ更新中のサイトに存在する PSC から ls_update_certs.py が使用されることを確認してください。

Platform Services Controller バージョン 6.0 の Windows インストールを実行している場合は、ls_update_certs.py スクリプトを実行する前に lstoolutil.py ファイルをこの記事に含まれるファイルに置き換える必要があります。vSphere 6.0 Update 1 を実行している場合はファイルを置き換える必要はありません。

lstoolutil.py ファイルを置き換えるには:
  1. 既存の "%VMWARE_CIS_HOME%"\VMware Identity Services\lstool\scripts\lstoolutil.py ファイルをバックアップします。デフォルトでは、この場所は C:\Program Files\VMware\vCenter Server\VMware Identity Services\lstool\scripts\ です。
  2. 添付の 2121701_lstoolutil.py.zip ファイルをダウンロードします。
  3. lstoolutil.py ファイルを 2121701_lstoolutil.py.zip ファイルから "%VMWARE_CIS_HOME%"\VMware Identity Services\lstool\scripts\ に抽出します。


Environment

VMware vCenter Server 6.0.x
VMware vCenter Server Appliance 6.7.x
VMware vCenter Server Appliance 6.0.x
VMware vCenter Server Appliance 6.5.x
VMware vCenter Server 6.5.x
VMware vCenter Server 6.7.x

Resolution

この問題は、vCenter Server 6.0 Update 1b で解決されており、VMware Downloads で入手できます。詳細については、『VMware vCenter Server 6.0 Update 1b Release Notes』を参照してください。
 
注:
  • 該当するシステムに vCenter Server 6.0 Update 1b をインストールしても、もう一度証明書を置き換えるまで、問題は解決しません。
  • この Update で解決されるのは、Certificate Manager ユーティリティを使用した証明書の置き換えの問題です。この Update で、Services Controller UI からの証明書の置き換えの問題は解決されません。
外部 Platform Services Controller のある環境でこの問題を回避するには、証明書を置き換えるたびに、vCenter Server システムと Platform Services Controller の両方の Lookup Service の登録情報を更新する必要があります。サービス登録情報を ls_update_certs.py スクリプトを使用して更新します。

  • 常に Platform Services Controller でこのスクリプトを実行してください。
  • スクリプトを実行するには、古い vCenter Server 証明書のサムプリントと新しい証明書が必要です。これらの証明書は、スクリプトを実行する前に Platform Services Controller にアップロードする必要があります。
  • スクリプトを実行する前に既存の証明書を必ずバックアップしてください。
  • 証明書を置き換えるたびにこのスクリプトを実行してください。

ソリューションの概要

スクリプトの実行方法は、マシン SSL 証明書を置き換えた場所により異なります。
 
証明書を Platform Services Controller のみで置き換えたPlatform Services Controller でスクリプトを実行し、Platform Services Controller の古い証明書および新しい証明書を渡します。
証明書を vCenter Server システム のみで置き換えたPlatform Services Controller でスクリプトを実行し、古い vCenter Server 証明書のサムプリントと新しい vCenter Server 証明書を渡します。
証明書を vCenter Server システムと Platform Services Controller の両方で置き換えた
Platform Services Controller で 2 回スクリプトを実行します。Platform Services Controller 証明書を置き換えた後、スクリプトを 1 度実行し、vCenter Server 証明書を置き換えた後再度実行するのが理想的です。


タスク 0:PSC と vCenter のための sslTrust アンカーを検証する

PSC アプライアンスのコマンド ラインから sslTrust アンカーを検証する
  1. SSH を使用して外部 Platform Services Controller アプライアンスにログインします。
  2. 次のコマンドを実行して、Bash シェルへのアクセスを有効にします。

    shell.set --enabled true
     
  3. shell」と入力し、Enter キーを押します。

    Platform Services Controller 上で SSL 証明書を置き換えた場合:
     
    1. 次のコマンドを実行して、Platform Services Controller のために格納された現在の sslTrust アンカーを取得します。

      /usr/lib/vmidentity/tools/scripts/lstool.py list --url https://localhost/lookupservice/sdk --no-check-cert --ep-type com.vmware.cis.cs.identity.sso 2>/dev/null

      例:

      :読みやすさを考慮して、SSL トラストは一部省略しています。

      Service Product: com.vmware.cis
      Service Type: cs.identity
      Service ID: 04608398-1493-4482-881b-b35961bf5141
      Site ID: vmware
      Owner ID: psc.vmware.local@vsphere.local
      Version: 2.0
      Endpoints:
      Type: com.vmware.cis.cs.identity.sso
      Protocol: wsTrust
      URL: https://homepsc.vmware.local/sts/STSService/vsphere.local
      SSL trust:
      MIIDWDCCAkCgAwIBAgIJANr+++MJ5+WxMA0GCSqGSIb3DQEBCwUAMGgxCzAJBgNV ... LqSKWg/apP1XlBV1VyC5LPZrH/rrq8+Naoj7i/P6HAzTwAAL+O10ggClaP8=
       
    2. 次のコマンドを実行して、Platform Services Controller のポート 443 で使用される現在の SSL 証明書を取得します。

      echo | openssl s_client -connect localhost:443

      例:

      :読みやすさを考慮して、実際の文字列を大幅に省略しています。

      CONNECTED(00000003)
      depth=3 /DC=local/DC=VMWARE/CN=VMWARE-WCA-CA-1
      verify return:1
      depth=2 /DC=local/DC=VMWARE/CN=VMWARE-WCAI-CA-1
      verify return:1
      depth=1 /C=US/DC=vsphere/DC=local/O=psc.vmware.local/CN=CA
      verify return:1
      depth=0 /CN=psc.vmware.local/C=US
      verify return:1
      ---
      Certificate chain
      0 s:/CN=psc.vmware.local/C=US
      i:/C=US/DC=vsphere/DC=local/O=psc.vmware.local/CN=CA
      ---
      Server certificate
      -----BEGIN CERTIFICATE-----

      MIIDWDCCAkCgAwIBAgIJANr+++MJ5+WxMA0GCSqGSIb3DQEBCwUAMGgxCzAJBgNV
      ...

      LqSKWg/apP1XlBV1VyC5LPZrH/rrq8+Naoj7i/P6HAzTwAAL+O10ggClaP8=
      -----END CERTIFICATE-----

       
    3. vSphere ドメインに複数の vCenter Server がある場合は、残りの VC ノードに対して FQDN を使用してコマンドを繰り返します。

      echo | openssl s_client -connect vcenter2.vmware.local:443
       
    4. openssl s_client と lstool.py の出力を使用して、返される SSL 証明書が vCenter Server に一致しているかどうかを確認します。一致する場合は、以降の手順を実行する必要はありません。一致しない場合は、「タスク 1:管理対象オブジェクト ブラウザ (MOB) から古い証明書を取得する」に進んで sslTrust アンカーの更新を開始します。
       

vCenter Server 上で SSL 証明書を置き換えた場合:

      1. 次のコマンドを実行して、vCenter Servers のために格納された現在の sslTrust アンカーを取得します。

        /usr/lib/vmidentity/tools/scripts/lstool.py list --url https://localhost/lookupservice/sdk --no-check-cert --ep-type com.vmware.vim 2>/dev/null

        例:

        :読みやすさを考慮して、SSL トラストは一部省略しています。

        Name: AboutInfo.vpx.name
        Description: AboutInfo.vpx.name
        Service Product: com.vmware.cis
        Service Type: vcenterserver
        Service ID: e29107d1-565d-436e-a0ed-6ecf1eb613a7
        Site ID: site
        Node ID: ffd86dd8-3f01-11e5-a40a-0050569c12c2
        Owner ID: vpxd-e4cd5699-d2e4-497b-9f48-aee8e31abb6b@vsphere.local
        Version: 6.0
        Endpoints:
        Type: com.vmware.vim
        Protocol: vmomi
        URL: https://vcenter.vmware.local:443/sdk
        SSL trust: MIIDfjCCAmagAwIBAgIJAMLCByASkdjPMA0GCSqGSIb3DQEBCwUAMGgxCzAJBgNV...v2zUN54IrTl1lfAA8eb6Xy9miKsYZoYan5mgzb+GGD2yLw==

         
      2. 次のコマンドを実行して、vCenter Server のポート 443 で使用される現在の SSL 証明書を取得します。

        echo | openssl s_client -connect vcenter_server_FQDN:443

        モデルとして以下の例を使用します。

        :読みやすさを考慮して、実際の文字列を大幅に省略しています。

        CONNECTED(00000003)
        depth=3 /DC=local/DC=VMWARE/CN=VMWARE-WCA-CA-1
        verify return:1
        depth=2 /DC=local/DC=VMWARE/CN=VMWARE-WCAI-CA-1
        verify return:1
        depth=1 /C=US/DC=vsphere/DC=local/O=psc.vmware.local/CN=CA
        verify return:1
        depth=0 /CN=vcenter.vmware.local/C=US
        verify return:1
        ---
        Certificate chain
        0 s:/CN=vcenter.vmware.local/C=US
        i:/C=US/DC=vsphere/DC=local/O=psc.vmware.local/CN=CA
        1 s:/C=US/DC=vsphere/DC=local/O=psc.vmware.local/CN=CA
        i:/DC=local/DC=VMWARE/CN=VMWARE-WCAI-CA-1
        2 s:/DC=local/DC=VMWARE/CN=VMWARE-WCAI-CA-1
        i:/DC=local/DC=VMWARE/CN=VMWARE-WCA-CA-1
        ---
        Server certificate
        -----BEGIN CERTIFICATE----

        MIIDfjCCAmagAwIBAgIJAMLCByASkdjPMA0GCSqGSIb3DQEBCwUAMGgxCzAJBgNV
        ...
        v2zUN54IrTl1lfAA8eb6Xy9miKsYZoYan5mgzb+GGD2yLw==

        -----END CERTIFICATE-----

         
      3. vSphere ドメインに複数の vCenter Server がある場合は、残りの VC ノードに対して FQDN を使用してコマンドを繰り返します。

        echo | openssl s_client -connect vcenter2.vmware.local:443
         
      4. openssl s_client と lstool.py の出力を使用して、出力される SSL 証明書が vCenter Server に一致しているかどうかを確認します。一致する場合は、以降の手順を実行する必要はありません。一致しない場合は、「タスク 1:管理対象オブジェクト ブラウザ (MOB) から古い証明書を取得する」に進んで sslTrust アンカーの更新を開始します。
     
    Windows PSC のインストールでコマンド ラインから sslTrust アンカーを検証する
    1. リモート デスクトップ接続および管理者認証情報を使用して、外部 Platform Services Controller に接続します。
    2. [スタート] > [実行] をクリックし、「cmd」と入力して [OK] をクリックします。
      Platform Services Controller 上で SSL 証明書を置き換えた場合:
      1. 次のコマンドを実行して、Platform Services Controller のために格納された現在の sslTrust アンカーを取得します。

        "%VMWARE_PYTHON_BIN%" "%VMWARE_CIS_HOME%\VMware Identity Services\lstool\scripts\lstool.py" list --url https://localhost/lookupservice/sdk --no-check-cert --ep-type com.vmware.cis.cs.identity.sso 2> NULL

        例:

        :読みやすさを考慮して、SSL トラストは一部省略しています。

        Service Product: com.vmware.cis
        Service Type: cs.identity
        Service ID: 04608398-1493-4482-881b-b35961bf5141
        Site ID: vmware
        Owner ID: psc.vmware.local@vsphere.local
        Version: 2.0
        Endpoints:
        Type: com.vmware.cis.cs.identity.sso
        Protocol: wsTrust
        URL: https://psc.vmware.local/sts/STSService/vsphere.local
        SSL trust: MIIDWDCCAkCgAwIBAgIJANr+++MJ5+WxMA0GCSqGSIb3DQEBCwUAMGgxCzAJBgNV ... LqSKWg/apP1XlBV1VyC5LPZrH/rrq8+Naoj7i/P6HAzTwAAL+O10ggClaP8=

         
      2. 次のコマンドを実行して、Platform Services Controller のポート 443 で使用される現在の SSL 証明書を取得します。

        "%VMWARE_OPENSSL_BIN%" s_client -connect localhost:443

        例:

        CONNECTED(00000003)
        depth=3 /DC=local/DC=VMWARE/CN=VMWARE-WCA-CA-1
        verify return:1
        depth=2 /DC=local/DC=VMWARE/CN=VMWARE-WCAI-CA-1
        verify return:1
        depth=1 /C=US/DC=vsphere/DC=local/O=psc.vmware.local/CN=CA
        verify return:1
        depth=0 /CN=psc.vmware.local/C=US
        verify return:1
        ---
        Certificate chain
        0 s:/CN=psc.vmware.local/C=US
        i:/C=US/DC=vsphere/DC=local/O=psc.fvmware.local/CN=CA
        ---
        Server certificate
        -----BEGIN CERTIFICATE-----

        MIIDWDCCAkCgAwIBAgIJANr+++MJ5+WxMA0GCSqGSIb3DQEBCwUAMGgxCzAJBgNV
        ...
        LqSKWg/apP1XlBV1VyC5LPZrH/rrq8+Naoj7i/P6HAzTwAAL+O10ggClaP8=

        -----END CERTIFICATE-----

         
      3. vSphere ドメインに複数の vCenter Server がある場合は、残りの  vCenter Server ノードに対して FQDN を使用してコマンドを繰り返します。

        "%VMWARE_OPENSSL_BIN%" s_client -connect vcenter2.vmware.local:443
         
      4. openssl s_client lstool.py の出力を使用して、出力される SSL 証明書が Platform Services Controller に一致しているかどうかを確認します。一致する場合は、以降の手順を実行する必要はありません。一致しない場合は、「タスク 1:管理対象オブジェクト ブラウザ (MOB) から古い証明書を取得する」に進んで sslTrust アンカーの更新を開始します。
         
        vCenter Server 上で SSL 証明書を置き換えた場合:
        1. 次のコマンドを実行して、vCenter Servers のために格納された現在の sslTrust アンカーを取得します。

          "%VMWARE_PYTHON_BIN%" "%VMWARE_CIS_HOME%\VMware Identity Services\lstool\scripts\lstool.py" list --url https://localhost/lookupservice/sdk --no-check-cert --ep-type com.vmware.vim 2>NULL

          例:

          :読みやすさを考慮して、SSL トラストは一部省略しています。

          Name: AboutInfo.vpx.name
          Description: AboutInfo.vpx.name
          Service Product: com.vmware.cis
          Service Type: vcenterserver
          Service ID: e29107d1-565d-436e-a0ed-6ecf1eb613a7
          Site ID: vmware
          Node ID: ffd86dd8-3f01-11e5-a40a-0050569c12c2
          Owner ID: vpxd-e4cd5699-d2e4-497b-9f48-aee8e31abb6b@vsphere.local
          Version: 6.0
          Endpoints:
          Type: com.vmware.vim
          Protocol: vmomi
          URL: https://vcenter.vmware.local:443/sdk
          SSL trust: MIIDfjCCAmagAwIBAgIJAMLCByASkdjPMA0GCSqGSIb3DQEBCwUAMGgxCzAJBgNV...v2zUN54IrTl1lfAA8eb6Xy9miKsYZoYan5mgzb+GGD2yLw==

           
        2. 次のコマンドを実行して、vCenter Server のポート 443 で使用される現在の SSL 証明書を取得します。

          "%VMWARE_OPENSSL_BIN%" s_client -connect vcenter_server_FQDN:443

          モデルとして以下の例を使用します。

          :読みやすさを考慮して、実際の文字列を大幅に省略しています。

          CONNECTED(00000003)
          depth=3 /DC=local/DC=VMWARE/CN=VMWARE-WCA-CA-1
          verify return:1
          depth=2 /DC=local/DC=VMWARE/CN=VMWARE-WCAI-CA-1
          verify return:1
          depth=1 /C=US/DC=vsphere/DC=local/O=psc.vmware.local/CN=CA
          verify return:1
          depth=0 /CN=vcenter.vmware.local/C=US
          verify return:1
          ---
          Certificate chain
          0 s:/CN=vcenter.vmware.local/C=US
          i:/C=US/DC=vsphere/DC=local/O=psc.vmware.local/CN=CA
          1 s:/C=US/DC=vsphere/DC=local/O=psc.vmware.local/CN=CA
          i:/DC=local/DC=VMWARE/CN=VMWARE-WCAI-CA-1
          2 s:/DC=local/DC=VMWARE/CN=VMWARE-WCAI-CA-1
          i:/DC=local/DC=VMWARE/CN=VMWARE-WCA-CA-1
          ---
          Server certificate
          -----BEGIN CERTIFICATE----

          MIIDfjCCAmagAwIBAgIJAMLCByASkdjPMA0GCSqGSIb3DQEBCwUAMGgxCzAJBgNV
          ...
          v2zUN54IrTl1lfAA8eb6Xy9miKsYZoYan5mgzb+GGD2yLw==

          -----END CERTIFICATE-----

           
        3. vSphere ドメインに複数の PSC がある場合は、残りの PSC ノードに対して FQDN を使用してコマンドを繰り返します。

          "%VMWARE_OPENSSL_BIN%" s_client -connect vcenter2.vmware.local:443
           
        4. openssl s_client lstool.py の出力を使用して、出力される SSL 証明書が vCenter Server に一致しているかどうかを確認します。一致する場合は、以降の手順を実行する必要はありません。一致しない場合は、「タスク 1:管理対象オブジェクト ブラウザ (MOB) から古い証明書を取得する」に進んで sslTrust アンカーの更新を開始します。

        タスク 1:管理対象オブジェクト ブラウザ (MOB) から古い証明書を取得する

        Platform Service Controller に管理対象オブジェクト ブラウザを使用して接続して vCenter Server システムの古い証明書を取得します。この手順を実行して、ArrayOfLookupServiceRegistrationInfo 管理対象オブジェクトの sslTrust フィールドを見つける必要があります。

        1. Platform Services Controller 上で古い証明書を格納するためのディレクトリを作成します。この記事のガイダンスに、次の場所を使用します。
           
          Platform Services Controller アプライアンス/certificates/
          Windows の Platform Services ControllerC:\certificates\

           
        2. MOB を開くには、ブラウザで https://psc.example.com/lookupservice/mob?moid=ServiceRegistration&method=List にアクセスします。
        3. 認証情報を求めるプロンプトが表示されたら、administrator@vsphere.local のユーザー名とパスワードを使用してログインします。
          vCenter Single Sign-On ドメインのカスタム名を使用している場合は、そのユーザー名とパスワードを使用します。
        4. [filterCriteria] テキスト フィールドで、タグ <filterCriteria></filterCriteria> のみが表示されるように値のフィールドを変更し、[メソッドの起動] をクリックします。
          これで ArrayOfLookupServiceRegistrationInfo オブジェクトが表示されます。
        5. どの証明書を置き換えるかに応じて以下を検索します。
           
          vCenter Serverページ上で vc_hostname_or_IP.example.com を検索 (Ctrl+F)
          Platform Services Controllerページ上で psc_hostname_or_IP.example.com を検索 (Ctrl+F)
        6. 対応する sslTrust フィールドの値を検索します。このフィールドの内容は古い証明書の Base64 エンコードされた文字列です。

          Platform Services Controller または vCenter Server のトラスト アンカーを更新するときのモデルとして次の例を使用します。

          :読みやすさを考慮して、実際の文字列を大幅に省略しています。

          vCenter Server の場合:
          sslTrustArrayofString

          MIIDfjCCAmag...

          urlanyURIhttps://vcenter.vmware.local:443/sdk

          Platform Services Controller の場合:
          sslTrustArrayofString

          MIIDfjCCAbad...

          urlanyURIhttps://psc.vmware.local/sts/STSService/vsphere.local
        7. [sslTrust] フィールドの内容をテキスト ドキュメントにコピーします。このドキュメントを old_machine.txt として保存します。
        8. テキスト エディタで old_machine.txt を開きます。
        9. 文字列の先頭に -----BEGIN CERTIFICATE----- を追加し、文字列の最後に -----END CERTIFICATE----- を追加します。sslTrust フィールドからコピーしたコンテンツの 64 文字目の後に改行を追加します。

          例:

          -----BEGIN CERTIFICATE-----
          LIIDeDCCAmCgAwIBAgIJAP7kGwWSSd0yMA0GCSqGSIb3DQEBCwUAMGgxCzAJBgNV
          PAMMAkNBMRcwFQYKCZImiZPyLGQBGRYHdnNwaGVyZTEVMBMGCgmSJomT8ixkARkW
          QWxvY2FsMQswCQYDVQQGEwJVUzEcMBoGA1UECgwTaG9tZXBzYy5mcml0ei5sb2Nh
          NDAeFw0xNTA4MTAwMDMwMjZaFw0yNTA4MDQwMDMwMjVaMCsxHDAaBgNVBAMME2hv
          HWVwc2MuZnJpdHoubG9jYWwxCzAJBgNVBAYTAlVTMIIBIjANBgkqhkiG9w0BAQEF
          LAOCAQ8AMIIBCgKCAQEAzuf/uVMLwlkUKsMXsUPigqZdrXKzEOEzOQ04q8YgVvDX
          w7MAPSTMZzeUsI6P+/4doZU14zAQTl/6dnbwYg65p9mv7CVJb4QgAJH9xFD+33Ab
          aQX7za/bWPgyxsPtccnn+si8QQDx9mMZbDzF0gjdARvpKWwVv4lln8iZ8wUahyC7
          bxnzc5/oWo4Z3DTruHMnvadHRZWzZTn8YeID06R2g8Yu5c50wXbAvNj3TE4x0Qyv
          fUbABXvv2EdYC5tb3g++L6A6tuWYgl+dr4KJ1G5gLvliECAsWsMwtQXq5nH65JdV
          XvRUVIlajC9OavGkd+ziT3yRibJBu2NJrLQp7ehgmQIDAQABo2IwYDAeBgNVHREE
          FzAVghNob21lcHNjLmZyaXR6LmxvY2FsMB0GA1UdDgQWBBSaRwv8djR7+qg7Wk3A
          zib3C3ArljAfBgNVHSMEGDAWgBRkYn4wsyRye8o14OoE3AOTMus6rzANBgkqhkiG
          9w0BAQsFAAOCAQEAU3X/ZEDXO8yDRJkjrQH0acxoc76QRDv+3s6yCpPFU8HmqU1E
          LmoDq67rHoKZw5ziBR/lGHn5oVHYYuJRFdO/b8NO1t2MnedhAaenqmAr4v0FzH6K
          UCgiLq8+ZMPFBz3qFu2i0I8mG6Yy0ud9T4wWUabgZ1C3sDNkQ+NLHXKVxNrPwgQd
          3KyrNpXgBQ0+ZWY3xvvdW5yOwnWkeAeqnGRYvzifG9M6DK/YMP1S/akAJvXSgEkJ
          PEJ3vlvSRy7l2lvU19upt4O/BAk3ZJ+X5uFtv/4GMdbEVZBCmNDS7Y85NorISiQf
          AVy/R2wjP4rNWDfN9DMCcwfPvw/0nFwrpr+0Cg==
          -----END CERTIFICATE-----

           
        10. old_machine.txt を old_machine.crt として保存します。
        11. 証明書を(WinSCP または別の SCP クライアントを介して)手順 1 で作成した場所の Platform Services Controller に移動またはアップロードします。
           
          Platform Services Controller アプライアンス/certificates/old_machine.crt
          Windows の Platform Services ControllerC:\certificates\old_machine.crt
        これで、サムプリントをこの証明書から抽出できます。タスク 2 に進みます。
         

        タスク 2:古い証明書からサムプリントを抽出する

        サムプリントは、コマンド ラインから、または証明書ビューア ツールを使用して抽出することができます。証明書を抽出したら、それを Platform Services Controller にアップロードすることができます。
         
        アプライアンスのコマンド ラインからサムプリントを抽出する
        1. SSH を使用して外部 Platform Services Controller アプライアンスにログインします。
        2. 次のコマンドを実行して、Bash シェルへのアクセスを有効にします。

          shell.set --enabled true
           
        3. shell」と入力し、Enter キーを押します。
        4. 次のコマンドを実行して、サムプリントを取得します。

          openssl x509 -in /certificates/old_machine.crt -noout -sha1 -fingerprint
           
        5. 次のように出力されます。

          SHA1 Fingerprint=13:1E:60:93:E4:E6:59:31:55:EB:74:51:67:2A:99:F8:3F:04:83:88

          等号の後に続く一連の数字と文字がサムプリントです。
         
        Windows インストールのコマンド ラインからサムプリントを抽出する
        1. 外部 Platform Services Controller にリモート デスクトップ接続します。
        2. 管理コマンド プロンプトを開きます。
        3. 次のコマンドを実行して、サムプリントを取得します。

          "%VMWARE_OPENSSL_BIN%" x509 -in c:\certificates\old_machine.crt -noout -sha1 -fingerprint
           
        4. 次のように出力されます。

          SHA1 Fingerprint=13:1E:60:93:E4:E6:59:31:55:EB:74:51:67:2A:99:F8:3F:04:83:88

          等号の後に続く一連の数字と文字がサムプリントです。

        証明書ビューア ツールを使用してサムプリントを抽出する

        下記の手順を行い、サムプリントを抽出できます。
        1. 証明書ビューア ツールを使用してファイルを開きます。Windows では、ファイルをダブルクリックすると Windows 証明書 ビューアで開きます。
        2. SHA1 サムプリント文字列を取得します。Windows 証明書 ビューアで SHA1 サムプリント フィールドを選択します。
        3. サムプリント文字列をプレーン テキスト エディタにコピーして、スペースをコロンに置き換えるか文字列からスペースを取り除きます。

          :テキスト エディタによっては、非表示文字が先頭に追加される場合があります。サムプリントの最初の文字と関連するスペースを削除し、文字を貼り付けるのではなく入力します。

        タスク 3 に進み、新しい証明書を取得します。

        タスク 3:新しい証明書を取得する

        置き換えている対象に応じて、新しい vCenter Server 証明書、新しい Platform Services Controller 証明書、またはその両方が必要となります。上述の「ソリューションの概要」を参照してください。

        新しい証明書をアーカイブしなかった場合は、vecs-cli を使用して取得できます。
         

        アプライアンスから新しい証明書を取得する

        1. コンソールまたは SSH セッションを介して vCenter Server または外部 Platform Services Controller アプライアンスにログインします。
        2. 次のコマンドを実行して、Bash シェルへのアクセスを有効にします。

          shell.set --enabled true
           
        3. shell」と入力し、Enter キーを押します。
        4. 次のコマンドを実行して、新しい証明書を表示します。

          /usr/lib/vmware-vmafd/bin/vecs-cli entry list --store MACHINE_SSL_CERT –-text
           
        5. 次のコマンドを実行して、新しい証明書をファイルにエクスポートします。

          /usr/lib/vmware-vmafd/bin/vecs-cli entry getcert --store MACHINE_SSL_CERT --alias __MACHINE_CERT --output /certificates/new_machine.crt
           
        6. vCenter Server 証明書を取得した場合は、スクリプトを実行する前に、(WinSCP または別の SCP クライアントを介して)Platform Services Controller に移動またはアップロードします。

        Windows インストールで新しい証明書を取得する

        1. リモート デスクトップで管理者認証情報を使用して vCenter Server または外部 Platform Services Controller に接続します。
        2. 管理コマンド プロンプトを開きます。
        3. 次のコマンドを実行して、新しい証明書を表示します。

          "%VMWARE_CIS_HOME%"\vmafdd\vecs-cli entry list --store MACHINE_SSL_CERT --text |more
           
        4. 次のコマンドを実行して、新しい証明書をファイルにエクスポートします。

          "%VMWARE_CIS_HOME%"\vmafdd\vecs-cli entry getcert --store MACHINE_SSL_CERT --alias __MACHINE_CERT --output c:\certificates\new_machine.crt
           
        5. vCenter Server 証明書を取得した場合は、スクリプトを実行する前に、(WinSCP または別の SCP クライアントを介して)Platform Services Controller に移動またはアップロードします。
        タスク 4 に進み、タスク 1 ~ 3 で収集した情報を使用して ls_update_certs スクリプトを実行します。
         

        タスク 4:ls_update_certs.py スクリプトを実行する

        Platform Services Controller で ls_update_certs.py スクリプトを実行します。スクリプトを正常に実行するには、vCenter Server または Platform Services Controller の古い証明書のサムプリントおよび vCenter Server または Platform Services Controller の新しい証明書の両方が必要です。
         
        :指定するパスワードに特殊文字またはスペースが含まれている場合は、引用符で囲みます(例. 'Passw0rd!')。パスワードに問題がある場合、以下のエラーメッセージと共にコマンドが失敗します。

        YYYY-MM-DD HH:MM:SS INFO com.vmware.vim.sso.client.impl.SecurityTokenServiceImpl$RequestResponseProcessor - Provided credentials are not valid.
        Caused by: com.vmware.vim.sso.client.exception.AuthenticationFailedException: Provided credentials are not valid.

         
        警告:このスクリプトのアクションは元に戻すことができません。問題が発生した場合にリカバリを行えるように、仮想マシンのバックアップまたはスナップショットを作成します。

        アプライアンスで ls_update_cert を実行する

        ls_update_certs スクリプトは /usr/lib/vmidentity/tools/scripts/ls_update_certs.py にあります。

        1. コンソールまたは SSH セッションを介して外部 Platform Services Controller アプライアンスにログインします。
        2. 次のコマンドを実行して、Bash シェルへのアクセスを有効にします。

          shell.set --enabled true
           
        3. shell」と入力し、Enter キーを押します。
        4. 次のコマンドを実行してディレクトリを /usr/lib/vmidentity/tools/scripts/に移動します。

          cd /usr/lib/vmidentity/tools/scripts/
           
        5. 次のコマンドを実行します:

          python ls_update_certs.py --url Lookup_Service_FQDN_of_Platform_Services_Controller --fingerprint Old_Certificate_Fingerprint_from_Task_2 --certfile New_Certificate_Path_from_Task_3 --user Administrator@vsphere.local --password "Password"

        6. 例(この例で使用されたフィンガープリントをコピーしない):

          python ls_update_certs.py --url https://psc.vmware.com/lookupservice/sdk --fingerprint 11:11:AF:D8:CF:27:6B:EF:F7:49:20:3E:D7:90:8C:F6:A0:A2:E2:30 --certfile /certificates/new_machine.crt --user Administrator@vsphere.local --password "Password"

        Platform Services Controller の Windows インストールで ls_update_cert を実行する

        1. 外部 Platform Services Controller にリモート デスクトップ接続します。
        2. 管理コマンド プロンプトを開きます。
        3. 次のコマンドを実行してディレクトリを C:\Program Files\VMware\vCenter Server\VMware Identity Services\lstool\scripts\ に移動します。

          cd C:\Program Files\VMware\vCenter Server\VMware Identity Services\lstool\scripts\
           
        4. 次のコマンドを実行します:

          "%VMWARE_PYTHON_BIN%" ls_update_certs.py --url Lookup_Service_FQDN_of_Platform_Services_Controller --fingerprint Old_Certificate_Fingerprint_from_Task_2 --certfile New_Certificate_Path_from_Task_3 --user Username --password Password

          例(この例で使用されたフィンガープリントをコピーしない):

          %VMWARE_PYTHON_BIN%" ls_update_certs.py --url https://psc.vmware.com/lookupservice/sdk --fingerprint 13:1E:60:93:E4:E6:59:31:55:EB:74:51:67:2A:99:F8:3F:04:83:88 --certfile c:\certificates\new_machine.crt --user Administrator@vsphere.local --password Password

        完了したら、タスク 0 を繰り返して PSC と vCenter エンドポイントが更新されていることを確認します


        追加情報

        ls_update_cert の構文

         
        次の構文を使用してスクリプトを実行します。

        python ls_update_certs.py --url LS_URL --fingerprint OLD_CERT_SHA1_HASH --certfile NEW_CERT_PEM_FILEPATH --user USER --password PASSWORD

         

        LS_URLLookup Service の URL。外部 Platform Services Controller で、次の URL をモデルとして使用します。
        https://external_platform_services_controller_FQDN.example.com/lookupservice/sdk
        OLD_CERT_SHA1_HASH
        タスク 2 で取得した、証明書を置き換える前に vCenter Server または Platform Services Controller が使用していた証明書のサムプリント。
        最初に古い証明書を取得します。
        • 可能な場合、証明書の置き換えを行う前に vCenter Server システムから現在の証明書をダウンロードします。詳細については、「How to download and install vCenter Server root certificates to avoid Web Browser certificate warnings (2108294)」を参照してください。
        • あるいは、以下の手順に従うこともできます:「タスク 1:管理対象オブジェクト ブラウザから古い証明書を取得する
        • 証明書を 1 つしか置き換えていない場合は、代わりに、「追加情報」に記載されている「管理対象オブジェクト ブラウザから古い証明書を取得する」の手順を使用することもできます。
        次に古い証明書からサムプリントを取り出します。
         
        :ファイルシステムでの古い vCenter Server 証明書の検索は推奨しません。
        NEW_CERT_PEM_FILEPATH
        タスク 3 で取得した、新しい vCenter Server マシン SSL 証明書の PEM エンコードされたファイル。
        証明書の置き換えの一部として渡したファイルを使用します。
        ファイルを持っていない場合は、「新しい証明書を取得する」の処理を行います。

        :ファイルシステムでの新しい vCenter Server 証明書の検索は推奨しません。

        USER and PASSWORDvCenter Single Sign-On の管理者権限を保有するユーザー

        BACKUP_STORE から古い証明書を取得する

         

        vSphere Certificate Manager ユーティリティを使用している場合は、古いマシンの SSL 証明書を VECS 内の BACKUP_STORE から取得できます。
         
        :バックアップ ストアは、最後の証明書のみ保存します。複数の置換動作を行う場合は、次で説明するように証明書を MOB から取得できます。
         
        vCenter Server Appliance では、古い証明書のサムプリントを次のように取得します:
        1. 次のコマンドを実行して、Machine_Cert エントリを探し、それが以前の証明書であることを確認します。

          /usr/lib/vmware-vmafd/bin/vecs-cli entry list --store BACKUP_STORE --text
           
        2. Machine_Cert の下の bkp___Machine_Cert に注意してください。
        3. 次のコマンドを実行して BACKUP_Store から Machine_Cert を出力します。

          /usr/lib/vmware-vmafd/bin/vecs-cli entry getcert --store BACKUP_STORE --alias bkp___MACHINE_CERT --output /certificates/old_machine.crt
           
        4. 次のコマンドを実行して、サムプリントを出力します。

          openssl certificate -fingerprint< -sha1 -noout old_machine.crt -in x509>

          出力は次のようになります。

          SHA1 Fingerprint=11:41:9F:D8:CF:27:6B:EA:F7:49:20:3E:D7:90:8C:F6:A0:62:E1:31
           

        vCenter Server Windows システムで、古い証明書を次のように取得します:

        1. 次のコマンドを実行して、Machine_Cert エントリを探し、それが以前の証明書であることを確認します。

          "%VMWARE_CIS_HOME%"\vmafdd\vecs-cli entry list --store BACKUP_STORE –text | more
           
        2. BACKUP_Store から Machine_Cert

        Additional Information

        vCenter Server or Platform Services Controller certificate validation error messages for external solutions in environments with a External Platform Services Controller