次の方法で共有


Azure Stack Hub PKI 証明書に関する一般的な問題を修復する

この記事の情報は、Azure Stack Hub PKI 証明書の一般的な問題について理解し、解決するうえで役立ちます。 Azure Stack Hub 適合性チェッカー ツールを使用して Azure Stack Hub PKI 証明書を検証すると、問題を見つけることができます。 このツールは、証明書が Azure Stack Hub デプロイと Azure Stack Hub シークレット ローテーションの PKI 要件を満たしていることを確認し、その結果のログを report.json ファイルに出力します。

HTTP CRL - 警告

問題 - 証明書に CDP 拡張機能の HTTP CRL が含まれていません。

解決策 - これは障害とならない問題です。 「Azure Stack Hub 公開キー インフラストラクチャ (PKI) 証明書の要件」に従って、Azure Stack には失効確認のために HTTP CRL が必要です。 証明書に HTTP CRL が検出されませんでした。 証明書の失効確認を確実に機能させるには、証明機関から CDP 拡張機能の HTTP CRL を含む証明書が発行される必要があります。

HTTP CRL - 失敗

問題 - CDP 拡張機能の HTTP CRL に接続できません。

解決策 - これは障害となっている問題です。 Azure Stack Hub の公開に関するページの「ポートとプロトコル (受信)」に従って、Azure Stack には失効確認のために HTTP CRL への接続が必要です。

PFX の暗号化

問題 - PFX 暗号化が TripleDES-SHA1 ではない。

解決策 - TripleDES-SHA1 暗号化を使用して PFX ファイルをエクスポートします。 これは、証明書スナップインからエクスポートするか Export-PFXCertificate を使用するときの、すべての Windows 10 クライアントの既定の暗号化の設定です。

PFX の読み取り

警告 - 証明書の個人情報がパスワードのみで保護されています。

解決策 - [証明書のプライバシーを有効にする] オプション設定を使用して PFX ファイルをエクスポートします。

問題 - PFX ファイルが無効です。

解決策 - 「デプロイ用の Azure Stack Hub PKI 証明書の準備」の手順を使用して、証明書を再度エクスポートします。

署名アルゴリズム

問題 - 署名アルゴリズムが SHA1 です。

解決策 - 「Azure Stack Hub 証明書署名要求の生成」の手順を使用して、署名アルゴリズム SHA256 で証明書署名要求 (CSR) を再生成します。 その後、CSR を証明機関に再送信して、証明書を再発行します。

秘密キー

問題 - 秘密キーがないか、秘密キーにローカル コンピューター属性が含まれていません。

解決策 - 「デプロイ用の Azure Stack Hub PKI 証明書の準備」の手順を使用して、CSR を生成したコンピューターから証明書を再度エクスポートします。 この手順には、ローカル コンピューターの証明書ストアからのエクスポートが含まれます。

証明書チェーン

問題 - 証明書チェーンが完全ではありません。

解決策 - 証明書には、完全な証明書チェーンが含まれている必要があります。 「デプロイ用の Azure Stack Hub PKI 証明書の準備」の手順を使用して証明書を再度エクスポートし、 [証明のパスにある証明書を可能であればすべて含む] オプションを選択します。

DNS 名

問題 - 証明書の DNSNameList に、Azure Stack Hub サービス エンドポイント名または有効なワイルドカード一致が含まれていません。 ワイルドカード一致は、DNS 名の左端の名前空間に対してのみ有効です。 たとえば、*.region.domain.comportal.region.domain.com のみで有効であり、*.table.region.domain.com では有効ではありません。

解決策 - 「Azure Stack Hub 証明書署名要求の生成」の手順を使用して、Azure Stack Hub エンドポイントをサポートする正しい DNS 名で CSR を再生成します。 CSR を証明機関に再送信します。 その後、「デプロイ用の Azure Stack Hub PKI 証明書の準備」の手順に従って、CSR を生成したマシンから、証明書をエクスポートします。

キー使用法

問題 - キー使用法に、デジタル署名またはキーの暗号化がありません。または拡張キー使用法に、サーバー認証またはクライアント認証がありません。

解決策 - 「Azure Stack Hub 証明書署名要求の生成」の手順を使用して、正しいキー使用法の属性で CSR を再生成します。 CSR を証明機関に再送信して、証明書テンプレートによって要求のキー使用法が上書きされていないことを確認します。

キー サイズ

問題 - キー サイズが 2,048 未満です。

解決策 - 「Azure Stack Hub 証明書署名要求の生成」の手順を使用して、正しいキーの長さ (2,048) で CSR を再生成し、CSR を証明機関に再送信します。

チェーンの順序

問題 - 証明書チェーンの順序が正しくありません。

解決策 - 「デプロイ用の Azure Stack Hub PKI 証明書の準備」の手順を使用して証明書を再度エクスポートし、 [証明のパスにある証明書を可能であればすべて含む] オプションを選択します。 リーフ証明書のみがエクスポート用に選択されていることを確認します。

他の証明書

問題 - PFX パッケージに、リーフ証明書または証明書チェーンの一部ではない証明書が含まれています。

解決策 - 「デプロイ用の Azure Stack Hub PKI 証明書の準備」の手順を使用して証明書を再度エクスポートし、 [証明のパスにある証明書を可能であればすべて含む] オプションを選択します。 リーフ証明書のみがエクスポート用に選択されていることを確認します。

パッケージに関する一般的な問題の修正

AzsReadinessChecker ツールには、Repair-AzsPfxCertificate というヘルパー コマンドレットが含まれています。これを使用すると、PFX ファイルをインポートしてからエクスポートし、パッケージに関する次のような一般的な問題を修正できます。

  • PFX 暗号化が TripleDES-SHA1 ではない。
  • 秘密キーにローカル コンピューター属性がない。
  • "証明書チェーン" が完全ではないか、間違っている PFX パッケージに証明書チェーンが含まれない場合、ローカル コンピューターに証明書チェーンを含める必要があります。
  • 他の証明書

新しい CSR を生成して証明書を再発行する必要がある場合は、Repair-AzsPfxCertificate は役に立ちません。

前提条件

ツールが実行されるコンピューターで、次の前提条件を満たす必要があります。

  • インターネットに接続された Windows 10 または Windows Server 2016。

  • PowerShell 5.1 以降。 バージョンを確認するには、次の PowerShell コマンドレットを実行し、"メジャー" バージョンと "マイナー" バージョンを調べます。

    $PSVersionTable.PSVersion
    
  • PowerShell for Azure Stack Hub を構成します。

  • 最新バージョンの Azure Stack Hub 適合性チェッカー ツールをダウンロードします。

既存の PFX ファイルのインポートとエクスポート

  1. 前提条件を満たしているコンピューターで、管理者特権の PowerShell プロンプトを開き、次のコマンドを実行して、Azure Stack Hub 適合性チェッカーをインストールします。

    Install-Module Microsoft.AzureStack.ReadinessChecker -Force -AllowPrerelease
    
  2. PowerShell プロンプトで次のコマンドレットを実行して、PFX パスワードを設定します。 パスワードの入力を求められたら、入力します。

    $password = Read-Host -Prompt "Enter password" -AsSecureString
    
  3. PowerShell プロンプトから次のコマンドを実行して、新しい PFX ファイルをエクスポートします。

    • -PfxPath には、操作する PFX ファイルへのパスを指定します。 次の例では、パスは .\certificates\ssl.pfx です。
    • -ExportPFXPath には、エクスポートする PFX ファイルの場所と名前を指定します。 次の例では、パスは .\certificates\ssl_new.pfx です。
    Repair-AzsPfxCertificate -PfxPassword $password -PfxPath .\certificates\ssl.pfx -ExportPFXPath .\certificates\ssl_new.pfx
    
  4. ツールが完了したら、成功したかどうかを出力で確認します。

    Repair-AzsPfxCertificate v1.1809.1005.1 started.
    Starting Azure Stack Hub Certificate Import/Export
    Importing PFX .\certificates\ssl.pfx into Local Machine Store
    Exporting certificate to .\certificates\ssl_new.pfx
    Export complete. Removing certificate from the local machine store.
    Removal complete.
    Log location (contains PII): C:\Users\username\AppData\Local\Temp\AzsReadinessChecker\AzsReadinessChecker.log
    Repair-AzsPfxCertificate Completed
    

次のステップ