虚拟投递代理 与 Delivery Controller™ 之间的 网络套接字 通信

本文介绍了如何为 VDA 与 Delivery Controller 之间的通信设置 WebSocket 连接,作为使用 WCF 通信的替代方案。其优势在于,VDA 到 Delivery Controller 的通信只需使用 TLS 端口 443。

目前,此功能仅适用于通过 MCS (Machine Creation Services) 预配的计算机。手动预配的计算机目前处于技术预览阶段。有关此功能的更多详细信息,请参阅 [Enroll non-MCS provisioned VDAs using tokens (Preview)]。

工作原理

以下部分描述了交付控制器与 VDA 之间 WebSocket 连接的工作流程:

  1. Citrix Virtual Apps and Desktops™ 管理员通过使用计算机创建服务 (MCS) 预配虚拟投递代理来启动此过程。
  2. 在 MCS 预配过程中,MCS 为每个 VDA 生成公钥-私钥对,并将公钥注册到 Delivery Controller 上的 FMA 信任服务。MCS 将公钥-私钥对作为文件保存在 VDA 上的身份磁盘下。
  3. 当 VDA 计算机启动时,安装在 VDA 计算机上的 MCS 代理从身份磁盘读取密钥对,并将此信息写入 VDA 注册表位置。
  4. 安装在 VDA 上的代理读取注册表中的密钥对,并向 Delivery Controller 生成一个启用 SSL 的 WebSocket 请求,其中服务密钥由私钥签名。
  5. Delivery Controller 使用 FMA 信任服务中的公钥验证签名的服务密钥授权标头。
  6. 验证完成后,系统在 VDA 和 交付控制器 之间建立 Web 套接字连接。

Web 套接字支持

开始之前

  1. 配置您的站点。有关详细信息,请参阅 创建站点
  2. 在 Delivery Controller 上安装 TLS 证书。有关详细信息,请参阅 在 Controller 上安装 TLS 服务器证书
  3. 在 VDA 上安装根证书颁发机构和中间证书颁发机构,以信任交付控制器。

操作步骤

按照说明设置 WebSocket 连接:

  1. 在交付控制器上启用 WebSocket 连接。在您站点上的每个交付控制器上运行以下命令:

    New-ItemProperty "HKLM:\SOFTWARE\Citrix\DesktopServer\WorkerProxy" -Name "WebSocket_Enabled" -PropertyType "DWord" -Value 1 -Force

    注意:

    确保在启用 WebSocket 后重新启动交付控制器。

  2. 为使用 MCS 预配的已加入 AD 的 VDA 创建计算机目录。有关详细信息,请参阅创建计算机目录
  3. 创建交付组并将您的 VDA 添加到其中。有关详细信息,请参阅创建交付组
  4. 需要在 VDA 上启用 WebSocket 连接。请在 VDA 上运行以下 PowerShell 命令:

    New-ItemProperty "HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\CitrixBrokerAgent\WebSocket" -Name "Enabled" -PropertyType "DWord" -Value 1 -Force
    <!--NeedCopy-->
    
    • 要检查 WebSocket 是否已启用,请检查以下注册表项值。Enabled 的值必须为 1。

      键:

       HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\CitrixBrokerAgent\WebSocket
       <!--NeedCopy-->
      

      名称:已启用

      Type: REG_DWORD

      值:1

虚拟投递代理 与 Delivery Controller™ 之间的 网络套接字 通信