StoreFront

StoreFront構成のエクスポートとインポート

注:

インポートできるStoreFront構成は、ターゲットのStoreFrontインストールと同じStoreFrontバージョンのものに限られます。

StoreFront展開の構成全体をエクスポートできます。これには、単一サーバー展開とサーバーグループ構成の両方が含まれます。インポート先のサーバーに既存の展開がすでに存在する場合、現在の構成は消去され、バックアップアーカイブに含まれる構成に置き換えられます。ターゲットサーバーがクリーンな工場出荷時のデフォルトインストールである場合、バックアップに保存されているインポートされた構成を使用して新しい展開が作成されます。エクスポートされた構成バックアップは、暗号化されていない場合は単一の.zipアーカイブ形式、バックアップファイルの作成時に暗号化を選択した場合は.ctxzip形式になります。

構成のエクスポートとインポートが使用できるシナリオ

  • 動作中の信頼できる状態のStoreFront展開のみをバックアップします。構成に変更を加える場合は、古いバックアップを置き換えるために新しいバックアップを作成する必要があります。backup.zipファイルのファイルハッシュが変更を防止するため、既存のバックアップを変更することはできません。
  • 災害復旧のためにStoreFrontをアップグレードする前にバックアップします。
  • 既存のテスト用StoreFront展開をクローンして本番環境に移行します。
  • 本番展開をテスト環境にクローンして、ユーザー受け入れ環境を作成します。
  • Windows Server 2019からWindows 2022へのホスティングのアップグレードなど、OS移行中にStoreFrontを移動します。インプレースOSアップグレードはサポートされていません。
  • 複数のデータセンターを持つ大規模企業など、マルチジオ展開で追加のサーバーグループを構築します。

StoreFront構成のエクスポートとインポートに関する考慮事項

  • 現在、Citrix®が公開している認証SDKの例(Magic Word認証やサードパーティ認証のカスタマイズなど)を使用していますか。その場合、追加の認証方法を含む構成をインポートする前にすべてのインポートサーバーにこれらのパッケージをインストールする必要があります。必要な認証SDKパッケージがインポートサーバーのいずれにもインストールされていない場合、構成のインポートは失敗します。サーバーグループに構成をインポートする場合は、グループのすべてのメンバーに認証パッケージをインストールしてください。
  • 構成バックアップを暗号化または復号化できます。エクスポートおよびインポートのPowerShellコマンドレットは、両方のユースケースをサポートしています。
  • 暗号化されたバックアップ(.ctxzip)は後で復号化できますが、StoreFrontは暗号化されていないバックアップファイル(.zip)を再暗号化することはできません。暗号化されたバックアップが必要な場合は、選択したパスワードを含むPowerShell資格情報オブジェクトを使用して、再度エクスポートを実行してください。
  • StoreFrontが現在インストールされているIISのWebサイトのSiteID(エクスポートサーバー)は、バックアップされたStoreFront構成を復元するIISのターゲットWebサイトのSiteID(インポートサーバー)と一致している必要があります。

PowerShellコマンドレット

Export-STFConfiguration

パラメーター 説明
-TargetFolder (String) バックアップアーカイブへのエクスポートパス。例: “$env:userprofile\desktop\”
-Credential (PSCredential Object) エクスポート中に暗号化された.ctxzipバックアップアーカイブを作成するための資格情報オブジェクトを指定します。PowerShell資格情報オブジェクトには、暗号化と復号化に使用するパスワードが含まれている必要があります。-Credential-NoEncryptionパラメーターと同時に使用しないでください。例: $CredObject
-NoEncryption (Switch) バックアップアーカイブが暗号化されていない.zipであることを指定します。-NoEncryption-Credentialパラメーターと同時に使用しないでください。
-ZipFileName (String) StoreFront構成バックアップアーカイブの名前。ファイル拡張子(.zipや.ctxzipなど)は追加しないでください。ファイル拡張子は、エクスポート時に-Credentialまたは-NoEncryptionパラメーターが指定されているかどうかに応じて自動的に追加されます。例: “backup”
-Force (Boolean) このパラメーターは、指定されたエクスポート場所にすでに存在する既存のバックアップファイルと同じファイル名のバックアップアーカイブを自動的に上書きします。

重要:

StoreFront 3.5にあったSiteIDパラメーターは、バージョン3.6で非推奨になりました。バックアップアーカイブに含まれるSiteIDが常に使用されるため、インポート時にSiteIDを指定する必要はなくなりました。SiteIDが、インポートサーバーのIISにすでに構成されている既存のStoreFront Webサイトと一致していることを確認してください。SiteID 1からSiteID 2への構成インポートはサポートされていません。

Import-STFConfiguration

パラメーター 説明
-ConfigurationZip (String) インポートするバックアップアーカイブへのフルパス。これにはファイル拡張子も含まれている必要があります。暗号化されていない場合は.zip、暗号化されている場合は.ctxzipを使用します。例: $env:userprofile\desktop\backup.ctxzip
-Credential (PSCredential Object) インポート中に暗号化されたバックアップを復号化するための資格情報オブジェクトを指定します。例: $CredObject
-HostBaseURL (String) このパラメーターが含まれている場合、指定したホストベースURLは、エクスポートサーバーからのホストベースURLの代わりに使用されます。例: https://<importingserver>.example.com

Unprotect-STFConfigurationBackup

パラメーター 説明
-TargetFolder (String)
-Credential (PSCredential Object)
バックアップアーカイブへのエクスポートパス。例: $env:userprofile\desktop
このパラメーターを使用して、暗号化されたバックアップアーカイブの暗号化されていないコピーを作成します。復号化に使用するパスワードを含むPowerShell資格情報オブジェクトを指定します。例: $CredObject
-EncryptedConfigurationZip (String) 復号化する暗号化されたバックアップアーカイブのフルパス。ファイル拡張子.ctxzipを指定する必要があります。例: $env:userprofile\\desktop\\backup.ctxzip
-OutputFolder (String)
-Force (Boolean)
暗号化された(.ctxzip)バックアップアーカイブの暗号化されていない(.zip)コピーを作成するパス。バックアップの元の暗号化されたコピーは再利用できるように保持されます。暗号化されていないコピーのファイル名とファイル拡張子は指定しないでください。例: $env:userprofile\desktop
このパラメーターは、指定されたエクスポート場所にすでに存在する既存のバックアップファイルと同じファイル名のバックアップアーカイブを自動的に上書きします。

構成のエクスポートとインポートの例

現在のPowerShellセッションにStoreFrontコマンドレットをインポートする

StoreFrontサーバーでPowerShell Integrated Scripting Environment (ISE) を開き、以下を実行します。

$env:PSModulePath = [Environment]::GetEnvironmentVariable('PSModulePath','Machine')
$SDKModules = 'C:\Program Files\Citrix\Receiver StoreFront\PowerShellSDK\Modules\Citrix.StoreFront'
Import-Module "$SDKModules\Citrix.StoreFront.psd1" -verbose
Import-Module "$SDKModules.Authentication\Citrix.StoreFront.Authentication.psd1" -verbose
Import-Module "$SDKModules.Roaming\Citrix.StoreFront.Roaming.psd1" -verbose
Import-Module "$SDKModules.Stores\Citrix.StoreFront.Stores.psd1" -verbose
Import-Module "$SDKModules.WebReceiver\Citrix.StoreFront.WebReceiver.psd1" -verbose
<!--NeedCopy-->

単一サーバーのシナリオ

サーバーA上の既存の構成の暗号化されていないバックアップを作成し、同じ展開に復元する

バックアップするサーバーの構成をエクスポートします。

Export-STFConfiguration -targetFolder "$env:userprofile\desktop\" -zipFileName "backup" -NoEncryption
<!--NeedCopy-->

backup.zipファイルを安全な場所にコピーします。このバックアップは、災害復旧のためにサーバーを以前の状態に復元するために使用できます。

Import-STFConfiguration -configurationZip "$env:userprofile\desktop\backup.zip" -HostBaseURL "https://storefront.example.com"
<!--NeedCopy-->

サーバーA上の既存の構成をバックアップし、サーバーBに復元して既存のサーバーのクローンを作成する

バックアップするサーバーの構成をエクスポートします。

Export-STFConfiguration -targetFolder "$env:userprofile\desktop\" -zipFileName "backup" -NoEncryption
<!--NeedCopy-->

backup.zipファイルをサーバーBのデスクトップにコピーします。

Import-STFConfiguration -configurationZip "$env:userprofile\desktop\backup.zip" -HostBaseURL "https://serverB.example.com"
<!--NeedCopy-->

StoreFrontがIISのカスタムWebサイトにすでに展開されている場合、構成を別のカスタムWebサイト展開に復元する

サーバーAには、通常のIISのデフォルトWebサイトではなく、カスタムWebサイトの場所にStoreFrontが展開されています。IISで作成された2番目のWebサイトのIIS SiteIDは2です。StoreFront Webサイトの物理パスは、d:\などの別の非システムドライブ上、またはデフォルトのc:\システムドライブ上にある可能性がありますが、IIS SiteIDは1より大きい値を使用する必要があります。

IIS内にStoreFrontという新しいWebサイトが構成されており、SiteID = 2を使用しています。StoreFrontは、物理パスがd:\inetpub\wwwroootにあるIISのカスタムWebサイトにすでに展開されています。

IIS Webサイトの追加ウィンドウのスクリーンショット

  1. サーバーAの構成のコピーをエクスポートします。
  2. サーバーBで、IISにStoreFrontという新しいWebサイトを構成し、これもSiteID 2を使用します。
  3. サーバーAの構成をサーバーBにインポートします。バックアップに含まれるサイトIDが使用され、StoreFront構成をインポートするターゲットWebサイトと一致している必要があります。

    Import-STFConfiguration -configurationZip "$env:userprofile\desktop\backup.ctxzip" -HostBaseURL "https://serverB.example.com"
    <!--NeedCopy-->
    

サーバーグループのシナリオ

シナリオ1: 既存のサーバーグループ構成をバックアップし、後で同じサーバーグループ展開に復元する

以前の構成バックアップは、2012R2-Aと2012R2-Bの2台のStoreFrontサーバーのみがサーバーグループのメンバーであったときに取得されました。バックアップアーカイブ内には、バックアップが取得された時点のCitrixClusterMembershipの記録があり、元の2台のサーバー2012R2-Aと2012R2-Bのみが含まれています。StoreFrontサーバーグループ展開は、ビジネス需要により元のバックアップが取得されて以来、サイズが増加し、追加ノード2012R2-Cがサーバーグループに追加されました。バックアップに保持されているサーバーグループの基盤となるStoreFront構成は変更されていません。元の2台のサーバーグループノードのみを含む古いバックアップがインポートされた場合でも、現在の3台のサーバーのCitrixClusterMembershipを維持する必要があります。インポート中に、現在のクラスターメンバーシップは保持され、構成がプライマリサーバーに正常にインポートされた後に書き戻されます。インポートは、元のバックアップが取得されて以来サーバーグループノードがサーバーグループから削除された場合でも、現在のCitrixClusterMembershipを保持します。

  1. サーバーグループ全体を管理するために使用されるプライマリサーバーである2012R2-Aから、サーバーグループ1の構成をエクスポートします。

    グループ1のCitrixClusterMembersPropertiesのスクリーンショット

  2. 後で、既存のサーバーグループに2012R2-Cという追加サーバーを追加します。

    グループ2のCitrixClusterMembersPropertiesのスクリーンショット

  3. サーバーグループの構成は、既知の以前に動作していた状態に復元する必要があります。StoreFrontは、インポートプロセス中に現在の3台のサーバーのCitrixClusterMembershipをバックアップし、インポートが成功した後に復元します。

  4. サーバーグループ1の構成をノード2012R2-Aにインポートし直します。

    Import-STFConfiguration -configurationZip "$env:userprofile\desktop\backup.ctxzip" -HostBaseURL "https://servergroup1.example.com"
    <!--NeedCopy-->
    
  5. 新しくインポートされた構成をサーバーグループ全体に伝播し、インポート後にすべてのサーバーが整合性のある構成を持つようにします。

シナリオ2: サーバーグループ1から既存の構成をバックアップし、それを使用して別の工場出荷時のデフォルトインストールに新しいサーバーグループを作成する。その後、新しいプライマリサーバーに他の新しいサーバーグループメンバーを追加できる

2012R2-Cと2012R2-Dの2台の新しいサーバーを含むサーバーグループ2が作成されます。サーバーグループ2の構成は、2012R2-Aと2012R2-Bの2台のサーバーも含む既存の展開であるサーバーグループ1の構成に基づきます。バックアップアーカイブに含まれるCitrixClusterMembershipは、新しいサーバーグループを作成する際には使用されません。現在のCitrixClusterMembershipは常にバックアップされ、インポートが成功した後に復元されます。インポートされた構成を使用して新しい展開を作成する場合、CitrixClusterMembershipセキュリティグループには、追加のサーバーが新しいグループに参加するまで、インポートサーバーのみが含まれます。サーバーグループ2は新しい展開であり、サーバーグループ1と共存することを意図しています。-HostBaseURLパラメーターを指定します。サーバーグループ2は、新しい工場出荷時のデフォルトのStoreFrontインストールを使用して作成されます。

  1. サーバーグループ全体を管理するために使用されるプライマリサーバーである2012R2-Aから、サーバーグループ1の構成をエクスポートします。

  2. サーバーグループ1の構成をノード2012R2-Cにインポートします。これは、新しく作成されたサーバーグループ2を管理するために使用されるプライマリサーバーになります。

    Import-STFConfiguration -configurationZip "$env:userprofile\desktop\backup.ctxzip" -HostBaseURL "https://servergroup2.example.com"
    <!--NeedCopy-->
    
  3. 新しいサーバーグループ2展開の一部となる追加のサーバーを参加させます。新しいサーバーが追加される際の通常の参加プロセスの一部として、サーバーグループ1からサーバーグループ2のすべての新しいメンバーへの新しくインポートされた構成の伝播は自動的に行われます。

シナリオ3: サーバーグループAから既存の構成をバックアップし、それを使用して既存のサーバーグループBの構成を上書きする

サーバーグループ1とサーバーグループ2は、2つの異なるデータセンターにすでに存在します。サーバーグループ1で多くのStoreFront構成変更が行われ、それらを別のデータセンターのサーバーグループ2に適用する必要があります。サーバーグループ1からサーバーグループ2に変更を移植できます。サーバーグループ2のバックアップアーカイブ内のCitrixClusterMembershipは使用しないでください。インポート中に-HostBaseURLパラメーターを指定します。これは、サーバーグループ2のホストベースURLを、サーバーグループ1で現在使用されているのと同じFQDNに変更すべきではないためです。サーバーグループ2は既存の展開です。

  1. サーバーグループ全体を管理するために使用されるプライマリサーバーである2012R2-Aから、サーバーグループ1の構成をエクスポートします。

  2. サーバーグループ1の構成をノード2012R2-Cの工場出荷時のデフォルトインストールにインポートします。これは、新しいサーバーグループ2のプライマリサーバーになります。

    Import-STFConfiguration -configurationZip "$env:userprofile\desktop\backup.zip" -NoEncryption -HostBaseURL "https://servergroup2.example.com"
    <!--NeedCopy-->
    

サーバー構成の暗号化されたバックアップを作成する

PowerShell資格情報オブジェクトは、Windowsアカウントのユーザー名とパスワードの両方で構成されます。PowerShell資格情報オブジェクトは、パスワードがメモリ内で保護された状態を保つことを保証します。

注:

構成バックアップアーカイブを暗号化するには、暗号化と復号化を実行するためのパスワードのみが必要です。資格情報オブジェクトに保存されているユーザー名は使用されません。エクスポートサーバーとインポートサーバーの両方で使用されるPowerShellセッション内に、同じパスワードを含む資格情報オブジェクトを作成する必要があります。資格情報オブジェクト内では、任意のユーザーを指定できます。

PowerShellでは、新しい資格情報オブジェクトを作成するときにユーザーを指定する必要があります。この例のコードは、便宜上、現在ログオンしているWindowsユーザーを取得します。

エクスポートサーバーのPowerShellセッション内にPowerShell資格情報オブジェクトを作成します。

$User = [System.Security.Principal.WindowsIdentity]::GetCurrent().Name
$Password = "Pa55w0rd"
$Password = $Password | ConvertTo-SecureString -asPlainText -Force
$CredObject = New-Object System.Management.Automation.PSCredential($User,$Password)
<!--NeedCopy-->

構成をbackup.ctxzip(暗号化されたzipファイル)にエクスポートします。

Export-STFConfiguration -targetFolder "$env:userprofile\desktop\" -zipFileName "backup" -Credential $CredObject
<!--NeedCopy-->

インポートサーバーのPowerShellセッション内に同一のPowerShell資格情報オブジェクトを作成します。

Import-STFConfiguration -configurationZip "$env:userprofile\desktop\backup.ctxzip" -Credential $CredObject -HostBaseURL "https://storefront.example.com"
<!--NeedCopy-->

既存の暗号化されたバックアップアーカイブの保護を解除する

$User = [System.Security.Principal.WindowsIdentity]::GetCurrent().Name
$Password = "Pa55w0rd"
$Password = $Password | ConvertTo-SecureString -asPlainText -Force
$CredObject = New-Object System.Management.Automation.PSCredential($User,$Password)

Unprotect-STFConfigurationExport -encryptedConfigurationZip "$env:userprofile\desktop\backup.ctxzip" -credential $CredObject -outputFolder "c:\StoreFrontBackups" -Force
<!--NeedCopy-->
StoreFront構成のエクスポートとインポート