安装适用于 SUSE 的 Linux 虚拟投递代理

您可以选择按照本文中的步骤进行手动安装,或使用 简易安装 进行自动安装和配置。简易安装可节省时间和精力,并且比手动安装更不容易出错。

注意:

仅将简易安装用于全新安装。请勿使用简易安装更新现有安装。

步骤 1:准备安装

步骤 1a:启动 YaST 工具

SUSE Linux Enterprise YaST 工具用于配置操作系统的所有方面。

要启动基于文本的 YaST 工具:

su -

yast
<!--NeedCopy-->

或者,启动基于 UI 的 YaST 工具:

su -

    -  yast2 &
<!--NeedCopy-->
-  ### 步骤 1b:配置网络

以下部分提供了有关配置 Linux VDA 使用的各种网络设置和服务的信息。网络配置通过 YaST 工具执行,而不是通过 Network Manager 等其他方法执行。这些说明基于使用基于 UI 的 YaST 工具。可以使用基于文本的 YaST 工具,但其导航方法不同,本文档中未对此进行说明。

配置主机名和 DNS

  1. 打开 YaST 网络设置。
  2. 仅限 SLED 12:在全局选项选项卡上,将网络设置方法更改为 Wicked Service
  3. 打开主机名/DNS选项卡。
  4. 清除通过 DHCP 更改主机名
  5. 选中将主机名分配给环回 IP
  6. 编辑以下内容以反映您的网络设置:
    • 主机名 – 添加计算机的 DNS 主机名。
    • 域名 – 添加计算机的 DNS 域名。
    • 名称服务器 – 添加 DNS 服务器的 IP 地址。这通常是 AD 域控制器的 IP 地址。
    • 域搜索列表 – 添加 DNS 域名。

注意:

Linux VDA 当前不支持 NetBIOS 名称截断。因此,主机名不得超过 15 个字符。 提示:

仅使用 a–z、A–Z、0–9 和连字符 (-) 字符。避免使用下划线 (_)、空格和其他符号。主机名不能以数字开头,也不能以连字符结尾。此规则也适用于 Delivery Controller 主机名。

禁用多播 DNS

仅在 SLED 上,默认设置已启用多播 DNS (mDNS),这可能导致名称解析结果不一致。mDNS 在 SLES 上默认未启用,因此无需执行任何操作。

要禁用 mDNS,请编辑 /etc/nsswitch.conf 并更改包含以下内容的行:

hosts: files mdns_minimal [NOTFOUND=return] dns

为:

hosts: files dns

检查主机名

验证主机名是否设置正确:

hostname
<!--NeedCopy-->

此命令仅返回计算机的主机名,而不返回其完全限定域名 (FQDN)。

验证 FQDN 是否设置正确:

    -  hostname -f
<!--NeedCopy-->
  • 此命令返回计算机的 FQDN。

  • 检查名称解析和服务可达性

    • 验证您是否可以解析 FQDN 并 ping 域控制器和 Delivery Controller™:
    -  nslookup domain-controller-fqdn

    -  ping domain-controller-fqdn

nslookup delivery-controller-fqdn

-  ping delivery-controller-fqdn
<!--NeedCopy-->
-  如果无法解析 FQDN 或 ping 通其中任何一台计算机,请在继续操作之前查看这些步骤。

-  ### 步骤 1c:配置 NTP 服务

保持 VDA、Delivery Controller 和域控制器之间精确的时钟同步至关重要。将 Linux VDA 作为虚拟机托管可能会导致时钟偏差问题。因此,首选使用远程 NTP 服务来维护时间。可能需要对默认 NTP 设置进行一些更改:

  1. 打开 YaST NTP 配置并选择常规设置选项卡。
  2. 在“启动 NTP 守护程序”部分中,选中立即和在启动时
    1. 如果存在,请选择未受控的本地时钟 (LOCAL) 项,然后单击删除
  1. 通过单击添加来添加 NTP 服务器条目。
  2. 选择服务器类型,然后单击下一步
  3. 在“地址”字段中键入 NTP 服务器的 DNS 名称。此服务通常托管在 Active Directory 域控制器上。
  4. 使“选项”字段保持不变。
  5. 单击测试以检查 NTP 服务是否可达。
      1. 单击一系列窗口中的确定以保存更改。

注意:

对于 SLES 12 实施,NTP 守护程序可能由于 SUSE 的 AppArmor 策略已知问题而无法启动。有关详细信息,请参阅解决方案

-  ### 步骤 1d:安装 Linux VDA 依赖包

适用于 SUSE Linux Enterprise 的 Linux VDA 软件依赖于以下软件包:

  • PostgreSQL
    • SLED/SLES 11:版本 9.1 或更高版本
    • SLED/SLES 12:版本 9.3 或更高版本
  • OpenJDK 1.7.0
  • OpenMotif 运行时环境 2.3.1 或更高版本
  • Cups
    • SLED/SLES 11:版本 1.3.7 或更高版本
    • SLED/SLES 12:版本 1.6.0 或更高版本
  • Foomatic filters
    • SLED/SLES 11:版本 3.0.0 或更高版本
    • SLED/SLES 12:版本 1.0.0 或更高版本
  • ImageMagick
    • SLED/SLES 11:版本 6.4.3.6 或更高版本
    • SLED/SLES 12:版本 6.8 或更高版本

添加存储库

某些必需的软件包并非在所有 SUSE Linux Enterprise 存储库中都可用:

  • SLED 11:PostgreSQL 适用于 SLES 11,但不适用于 SLED 11。
  • SLES 11:OpenJDK 和 OpenMotif 适用于 SLED 11,但不适用于 SLES 11。
  • SLED 12:PostgreSQL 适用于 SLES 12,但不适用于 SLED 12。ImageMagick 可通过 SLE 12 SDK ISO 或在线存储库获取。
  • SLES 12:没有问题。所有软件包均可用。ImageMagick 可通过 SLE 12 SDK ISO 或在线存储库获取。

要解决此问题,请从您正在安装的 SLE 替代版本的介质中获取缺失的软件包。也就是说,在 SLED 上从 SLES 介质安装缺失的软件包,在 SLES 上从 SLED 介质安装缺失的软件包。以下方法挂载 SLED 和 SLES ISO 介质文件并添加存储库。

  • 在 SLED 11 上,运行以下命令:
sudo mkdir -p /mnt/sles

sudo mount -t iso9660 path-to-iso/SLES-11-SP4-DVD-x86_64-GM-DVD1.iso /mnt/sles

sudo zypper ar -f /mnt/sles sles
<!--NeedCopy-->
  • 在 SLES 11 上,运行以下命令:
sudo mkdir -p /mnt/sled

sudo mount -t iso9660 path-to-iso/SLED-11-SP4-DVD-x86_64-GM-DVD1.iso /mnt/sled

sudo zypper ar -f /mnt/sled sled
<!--NeedCopy-->
  • 在 SLED 12 上,运行以下命令:
    -  sudo mkdir -p /mnt/sles

sudo mount -t iso9660 path-to-iso/SLES-12-SP2-DVD-x86_64-GM-DVD1.iso /mnt/sles

sudo zypper ar -f /mnt/sles sles
<!--NeedCopy-->
-  在 SLED/SLES 12 上,运行以下命令:
sudo mkdir -p /mnt/sdk

sudo mount -t iso9660 path-to-iso/SLE-12-SP3-SDK-DVD-x86_64-GM-DVD1.iso /mnt/sdk

    -  sudo zypper ar -f /mnt/sdk sdk
<!--NeedCopy-->

安装 Kerberos 客户端

安装 Kerberos 客户端以在 Linux VDA 和 Delivery Controller 之间进行相互身份验证:

sudo zypper install krb5-client
<!--NeedCopy-->

Kerberos 客户端配置取决于所使用的 Active Directory 集成方法。请参阅以下说明。

安装 OpenJDK

Linux VDA 依赖于 OpenJDK 1.7.0。

提示: - > 为避免出现问题,请确保仅安装了 OpenJDK 版本 1.7.0。删除系统上的所有其他 Java 版本。

-  **SLED:**
  1. 在 SLED 上,Java 运行时环境通常随操作系统一起安装。检查是否已安装:

    sudo zypper info java-1_7_0-openjdk
    <!--NeedCopy-->
    
  2. 如果状态报告为“过期”,请更新到最新版本:

    sudo zypper update java-1_7_0-openjdk
    <!--NeedCopy-->
    
    1. 检查 Java 版本:
     java -version
     <!--NeedCopy-->
    
  • SLES:
  1. 在 SLES 上,安装 Java 运行时环境:

    sudo zypper install java-1_7_0-openjdk
    <!--NeedCopy-->
    
  2. 检查 Java 版本:

    java -version
    <!--NeedCopy-->
    

安装 PostgreSQL

  • 在 SLED/SLES 11 上,安装软件包:

     sudo zypper install libecpg6
    
     sudo zypper install postgresql-init
    
     sudo zypper install postgresql
    
     sudo zypper install postgresql-server
    
     sudo zypper install postgresql-jdbc
     <!--NeedCopy-->
    

    需要执行安装后步骤来初始化数据库服务,并确保在计算机启动时启动 PostgreSQL:

     sudo /sbin/insserv postgresql
    
     sudo /etc/init.d/postgresql restart
    
     <!--NeedCopy-->
    
  • 在 SLED/SLES 12 上,安装软件包:

     -  sudo zypper install postgresql-init
    
     -  sudo zypper install postgresql-server
    
     sudo zypper install postgresql-jdbc
     <!--NeedCopy-->
    

    需要执行安装后步骤来初始化数据库服务,并确保在计算机启动时启动 PostgreSQL:

     sudo systemctl enable postgresql
    
     sudo systemctl restart postgresql
     <!--NeedCopy-->
    

    数据库文件位于 /var/lib/pgsql/data。

删除存储库

安装完依赖软件包后,现在可以删除之前设置的备用版本存储库并卸载介质:

-  在 SLED 11 上,运行以下命令删除软件包:

```
sudo zypper rr sles

sudo umount /mnt/sles

sudo rmdir /mnt/sles
<!--NeedCopy--> ```

-  在 SLES 11 上,运行以下命令删除软件包:

```
sudo zypper rr sled

sudo umount /mnt/sled

sudo rmdir /mnt/sled
<!--NeedCopy--> ```

-  在 SLED 12 上,运行以下命令删除软件包:

```
sudo zypper rr sles

sudo umount /mnt/sles

sudo rmdir /mnt/sles
<!--NeedCopy--> ```
  • 在 SLED/SLES 12 上,运行以下命令删除软件包:

     sudo zypper rr sdk
    
     sudo umount /mnt/sdk
    
     sudo rmdir /mnt/sd
     <!--NeedCopy-->
    

步骤 2:为虚拟机管理程序准备 Linux VM

在受支持的虚拟机管理程序上将 Linux VDA 作为虚拟机运行时,需要进行一些更改。请根据所使用的虚拟机管理程序平台进行以下更改。如果您在裸机硬件上运行 Linux 计算机,则无需进行任何更改。

修复 Citrix XenServer® 上的时间同步

如果启用了 XenServer 时间同步功能,则在每个半虚拟化 Linux VM 中,您都会遇到 NTP 和 XenServer 都尝试管理系统时钟的问题。为避免时钟与其他服务器不同步,每个 Linux 访客中的系统时钟必须与 NTP 同步。此情况需要禁用主机时间同步。在 HVM 模式下无需进行任何更改。

在某些 Linux 发行版上,如果您正在运行安装了 XenServer Tools 的半虚拟化 Linux 内核,则可以从 Linux VM 中检查 XenServer 时间同步功能是否存在并已启用:

su -

cat /proc/sys/xen/independent_wallclock
<!--NeedCopy-->

此命令返回 0 或 1:

  • 0 - 时间同步功能已启用,必须禁用。
  • 1 - 时间同步功能已禁用,无需进一步操作。

如果 /proc/sys/xen/indepent_wallclock 文件不存在,则无需执行以下步骤。

如果已启用,请通过向文件写入 1 来禁用时间同步功能:

sudo echo 1 > /proc/sys/xen/independent_wallclock
<!--NeedCopy-->

要在重新启动后使此更改永久生效,请编辑 /etc/sysctl.conf 文件并添加以下行:

xen.independent_wallclock = 1

要验证这些更改,请重新启动系统:

reboot
<!--NeedCopy-->

重新启动后,检查设置是否正确:

su -
cat /proc/sys/xen/independent_wallclock
<!--NeedCopy-->

此命令返回值为 1。

修复 Microsoft Hyper-V 上的时间同步

安装了 Hyper-V Linux Integration Services 的 Linux VM 可以应用 Hyper-V 时间同步功能来使用主机操作系统的时钟。为确保系统时钟保持准确,请与 NTP 服务一起启用此功能。

从管理操作系统:

  1. 打开 Hyper-V 管理器控制台。
  2. 对于 Linux VM 的设置,选择集成服务
  3. 确保选中时间同步

注意:

此方法与 VMware 和 XenServer 不同,在 VMware 和 XenServer 中,主机时间同步被禁用以避免与 NTP 冲突。Hyper-V 时间同步可以与 NTP 时间同步共存并对其进行补充。

修复 ESX 和 ESXi 上的时间同步

如果启用了 VMware 时间同步功能,则在每个半虚拟化 Linux VM 中,您都会遇到 NTP 和虚拟机管理程序都尝试同步系统时钟的问题。为避免时钟与其他服务器不同步,每个 Linux 访客中的系统时钟必须与 NTP 同步。此情况需要禁用主机时间同步。

如果您正在运行安装了 VMware Tools 的半虚拟化 Linux 内核:

  1. 打开 vSphere Client。
  2. 编辑 Linux VM 的设置。
  3. 虚拟机属性对话框中,打开选项选项卡。
  4. 选择 VMware Tools
  5. 高级框中,清除将访客时间与主机同步

步骤 3:将 Linux 虚拟机 (VM) 添加到 Windows 域

Linux VDA 支持多种方法将 Linux 计算机添加到 Active Directory (AD) 域:

  • Samba Winbind
  • Quest Authentication Service
  • Centrify DirectControl

根据您选择的方法执行说明。

Samba Winbind

加入 Windows 域

您的域控制器必须可访问,并且您必须拥有一个具有将计算机添加到域权限的 Active Directory 用户帐户:

  1. 打开 YaST Windows 域成员身份。

  2. 进行以下更改:

    • 域或工作组设置为您的 Active Directory 域的名称或域控制器的 IP 地址。确保域名为大写。
    • 选中也使用 SMB 信息进行 Linux 身份验证
    • 选中登录时创建主目录
    • 选中SSH 单点登录
    • 确保未选中脱机身份验证。此选项与 Linux VDA 不兼容。
  3. 单击“确定”。如果提示安装某些软件包,请单击“安装”。

  4. 如果找到域控制器,它会询问您是否要加入域。单击“”。

  5. 出现提示时,键入有权将计算机添加到域的域用户的凭据,然后单击“确定”。

  6. 显示一条指示成功的消息。

  7. 如果提示安装某些 Samba 和 krb5 软件包,请单击“安装”。

YaST 可能已指示这些更改需要重新启动某些服务或计算机。建议您重新启动计算机:

su -

reboot
<!--NeedCopy-->

仅限 SLED/SLES 12:修补 Kerberos 凭据缓存名称

SLED/SLES 12 已将默认 Kerberos 凭据缓存名称规范从常用的 FILE:/tmp/krb5cc_%{uid} 更改为 DIR:/run/user/%{uid}/krb5cc。此新的 DIR 缓存方法与 Linux VDA 不兼容,必须手动更改。作为 root 用户,编辑 /etc/krb5.conf 并在 [libdefaults] 部分下添加以下设置(如果未设置):

default_ccache_name = FILE:/tmp/krb5cc_%{uid}

验证域成员身份

Delivery Controller 要求所有 VDA 计算机(Windows 和 Linux VDA)在 Active Directory 中都具有计算机对象。

运行 Samba 的 net ads 命令以验证计算机是否已加入域:

sudo net ads testjoin
<!--NeedCopy-->

运行以下命令以验证额外的域和计算机对象信息:

sudo net ads info
<!--NeedCopy-->

验证 Kerberos 配置

为确保正确配置 Kerberos 以便与 Linux VDA 结合使用,请检查是否已创建系统 keytab 文件并包含有效密钥:

sudo klist –ke
<!--NeedCopy-->

此命令显示可用密钥的列表,适用于主体名称和密码套件的各种组合。运行 Kerberos kinit 命令以使用这些密钥通过域控制器对计算机进行身份验证:

sudo kinit -k MACHINE\$@REALM
<!--NeedCopy-->

计算机和领域名称必须以大写形式指定。美元符号 ($) 必须使用反斜杠 (\) 进行转义,以防止 shell 替换。在某些环境中,DNS 域名与 Kerberos 领域名称不同。请确保使用领域名称。如果此命令成功,则不显示任何输出。

验证计算机帐户的 TGT 票证是否已缓存:

sudo klist
<!--NeedCopy-->

检查计算机帐户详细信息:

sudo net ads status
<!--NeedCopy-->

验证用户身份验证

使用 wbinfo 工具验证域用户是否可以使用域进行身份验证:

wbinfo --krb5auth=domain\\username%password
<!--NeedCopy-->

此处指定的域是 AD 域名,而不是 Kerberos 领域名称。对于 bash shell,反斜杠 (\) 字符必须使用另一个反斜杠进行转义。此命令返回一条指示成功或失败的消息。

要验证 Winbind PAM 模块是否已正确配置,请使用域用户帐户登录到 Linux VDA。此域用户帐户以前未使用过。

ssh localhost -l domain\\username

id -u
<!--NeedCopy-->

检查是否已为 id -u 命令返回的 uid 创建了相应的 Kerberos 凭据缓存文件:

ls /tmp/krb5cc_uid
<!--NeedCopy-->

检查用户 Kerberos 凭据缓存中的票证是否有效且未过期:

klist
<!--NeedCopy-->

退出会话

exit
<!--NeedCopy-->

可以通过直接登录到 Gnome 或 KDE 控制台来执行类似的测试。在完成域加入验证后,继续执行步骤 4:安装 Linux VDA

Quest 身份验证服务

在域控制器上配置 Quest

假设您已在 Active Directory 域控制器上安装并配置了 Quest 软件,并且已获得在 Active Directory 中创建计算机对象的管理权限。

启用域用户登录到 Linux VDA 计算机

要使域用户能够在 Linux VDA 计算机上建立 HDX™ 会话:

  1. 在 Active Directory 用户和计算机管理控制台中,打开该用户帐户的 Active Directory 用户属性。
  2. 选择“Unix 帐户”选项卡。
  3. 选中“启用 Unix”。
  4. 将“主 GID 号”设置为实际域用户组的组 ID。

注意:

这些说明等同于设置域用户以使用控制台、RDP、SSH 或任何其他远程处理协议进行登录。

在 Linux VDA 上配置 Quest

  • 配置 VAS 守护程序
  • 必须启用 Kerberos 票证的自动续订,并禁用脱机身份验证(脱机登录):
    -  sudo /opt/quest/bin/vastool configure vas vasd auto-ticket-renew-interval 32400

    -  sudo /opt/quest/bin/vastool configure vas vas_auth allow-disconnected-auth false
<!--NeedCopy-->
  • 此命令将续订间隔设置为九小时(32,400 秒),比默认的 10 小时票证有效期少一小时。在票证有效期较短的系统上,将此参数设置为较低的值。

  • 配置 PAM 和 NSS
  • 要通过 HDX 和其他服务(例如 su、ssh 和 RDP)启用域用户登录,请运行以下命令以手动配置 PAM 和 NSS:
sudo /opt/quest/bin/vastool configure pam

sudo /opt/quest/bin/vastool configure nss
<!--NeedCopy-->

加入 Windows 域

使用 Quest 的 vastool 命令将 Linux 计算机加入 Active Directory 域:

sudo /opt/quest/bin/vastool -u user join domain-name
<!--NeedCopy-->

user 是具有将计算机加入 Active Directory 域权限的任何域用户。domain-name 是域的 DNS 名称,例如 example.com。

验证域成员身份

Delivery Controller 要求所有 VDA 计算机(Windows VDA 和 Linux VDA)在 Active Directory 中具有计算机对象。要验证已加入 Quest 的 Linux 计算机是否在域中:

sudo /opt/quest/bin/vastool info domain
<!--NeedCopy-->

如果计算机已加入域,此命令将返回域名。如果计算机未加入任何域,则显示以下错误:

ERROR: No domain could be found. ERROR: VAS_ERR_CONFIG: at ctx.c:414 in _ctx_init_default_realm default_realm not configured in vas.conf. Computer may not be joined to domain

验证用户身份验证

要验证 Quest 是否可以通过 PAM 验证域用户,请使用以前未曾使用过的域用户帐户登录到 Linux VDA。

ssh localhost -l domain\\username

id -u
<!--NeedCopy-->

检查是否为 id -u 命令返回的 uid 创建了相应的 Kerberos 凭据缓存文件:

ls /tmp/krb5cc_uid
<!--NeedCopy-->

检查 Kerberos 凭据缓存中的票证是否有效且未过期:

/opt/quest/bin/vastool klist
<!--NeedCopy-->

退出会话。

exit
<!--NeedCopy-->

可以通过直接登录到 Gnome 或 KDE 控制台来执行类似的测试。完成域加入验证后,请继续执行步骤 4:安装 Linux VDA

Centrify DirectControl

加入 Windows 域

安装 Centrify DirectControl Agent 后,使用 Centrify 的 adjoin 命令将 Linux 计算机加入 Active Directory 域:

su –

adjoin -w -V -u user domain-name
<!--NeedCopy-->

user 是具有将计算机加入 Active Directory 域权限的任何 Active Directory 域用户。domain-name 是要将 Linux 计算机加入的域的名称。

验证域成员身份

Delivery Controller 要求所有 VDA 计算机(Windows VDA 和 Linux VDA)在 Active Directory 中具有计算机对象。要验证已加入 Centrify 的 Linux 计算机是否在域中:

-  su –

    -  adinfo
<!--NeedCopy-->
  • 检查 Joined to domain 值是否有效,以及 CentrifyDC mode 是否返回 connected。如果模式停留在启动状态,则 Centrify 客户端正在遇到服务器连接或身份验证问题。

可以使用以下命令获取更全面的系统和诊断信息:

adinfo --sysinfo all

adinfo –diag
<!--NeedCopy-->

测试与各种 Active Directory 和 Kerberos 服务的连接。

-  adinfo --test
<!--NeedCopy-->

完成域加入验证后,请继续执行步骤 4:安装 Linux VDA

步骤 4:安装 Linux VDA

步骤 4a:卸载旧版本

如果您安装的版本早于前两个版本和 LTSR 版本,请在新版本安装之前将其卸载。

  1. 停止 Linux VDA 服务:

    sudo /sbin/service ctxvda stop
    
    sudo /sbin/service ctxhdx stop
    <!--NeedCopy-->
    
  2. 卸载软件包:

    sudo rpm -e XenDesktopVDA
    <!--NeedCopy-->
    

重要:

支持从前两个版本进行升级。

注意:

安装组件位于 /opt/Citrix/VDA/ 中。

要运行命令,需要完整的路径;或者,您可以将 /opt/Citrix/VDA/sbin/opt/Citrix/VDA/bin 添加到系统路径。

步骤 4b:下载 Linux VDA 软件包

转到 Citrix 网站,根据您的 Linux 发行版下载相应的 Linux VDA 软件包。

步骤 4c:安装 Linux VDA

使用 Zypper 安装 Linux VDA 软件:

对于 SUSE 12:

sudo zypper install XenDesktopVDA-7.15.0.404-1.sle12_2.x86_64.rpm
<!--NeedCopy-->

对于 SUSE 11:

sudo zypper install XenDesktopVDA-7.15.0.404-1.sle11_4.x86_64.rpm
<!--NeedCopy-->

使用 RPM 软件包管理器安装 Linux VDA 软件。在此之前,请解决以下依赖项:

对于 SUSE 12:

sudo rpm -i XenDesktopVDA-7.15.0.404-1.sle12_2.x86_64.rpm
<!--NeedCopy-->

对于 SUSE 11:

sudo rpm -i XenDesktopVDA-7.15.0.404-1.sle11_4.x86_64.rpm
<!--NeedCopy-->

步骤 4d:升级 Linux VDA(可选)

您可以使用 RPM 软件包管理器从版本 7.14 和 7.13 升级 Linux VDA 软件:

对于 SUSE 12:

sudo rpm -U XenDesktopVDA-7.15.0.404-1.sle12_2.x86_64.rpm
<!--NeedCopy-->

对于 SUSE 11:

sudo rpm -U XenDesktopVDA-7.15.0.404-1.sle11_4.x86_64.rpm
<!--NeedCopy-->

适用于 SUSE 12 的 RPM 依赖项列表:

postgresql-server >= 9.3

postgresql-jdbc >= 9.2

java-1.7.0-openjdk >= 1.7.0

ImageMagick >= 6.8

dbus-1 >= 1.8.8

dbus-1-x11 >= 1.8.8

libXpm4 >= 3.5.11

libXrandr2 >= 1.4.2

libXtst6 >= 1.2.2

motif >= 2.3

pam >= 1.1.8

bash >= 4.2

findutils >= 4.5

gawk >= 4.1

sed >= 4.2

cups >= 1.6.0

cups-filters-foomatic-rip >= 1.0.0

openldap2 >= 2.4

cyrus-sasl >= 2.1

cyrus-sasl-gssapi >= 2.1

libxml2 >= 2.9

python-requests >= 2.8.1

rpmlib(PayloadFilesHavePrefix) <= 4.0-1

rpmlib(CompressedFileNames) <= 3.0.4-1

rpmlib(PayloadIsLzma) <= 4.4.6-1
<!--NeedCopy-->

适用于 SUSE 11 的 RPM 依赖项列表:

postgresql-server >= 9.1.

postgresql-jdbc >= 9.1

java-1_7_0-openjdk >= 1.7.0.6

ImageMagick >= 6.4.3.6

ConsoleKit >= 0.2.10

dbus-1 >= 1.2.10

dbus-1-x11 >= 1.2.10

xorg-x11-libXpm >= 7.4

xorg-x11-libs >= 7.4

openmotif-libs >= 2.3.1

pam >= 1.1.5

libdrm >= 2.4.41

libpixman-1-0 >= 0.24.4

Mesa >= 9.0

openssl >= 0.9.8j

xorg-x11 >= 7.4

xorg-x11-fonts-core >= 7.4

xorg-x11-libXau >= 7.4

xorg-x11-libXdmcp >= 7.4

bash >= 3.2

findutils >= 4.4

gawk >= 3.1

sed >= 4.1

cups >= 1.3.7

foomatic-filters >= 3.0.0

openldap2 >= 2.4

cyrus-sasl >= 2.1

cyrus-sasl-gssapi >= 2.1

libxml2 >= 2.7

python-requests >= 2.0.1

rpmlib(PayloadFilesHavePrefix) <= 4.0-1

rpmlib(CompressedFileNames) <= 3.0.4-1

rpmlib(PayloadIsLzma) <= 4.4.6-1
<!--NeedCopy-->

重要:

升级后请重新启动 Linux VDA 计算机。

步骤 5:配置 Linux VDA

安装软件包后,必须通过运行 ctxsetup.sh 脚本来配置 Linux VDA。在进行任何更改之前,脚本会验证环境并确保所有依赖项均已安装。如有必要,您可以随时重新运行该脚本以更改设置。

您可以手动运行脚本并进行提示,也可以使用预配置的响应自动运行脚本。在继续操作之前,请查看有关该脚本的帮助:

sudo /opt/Citrix/VDA/sbin/ctxsetup.sh –help
<!--NeedCopy-->

提示式配置

运行手动配置并回答提示问题:

sudo /opt/Citrix/VDA/sbin/ctxsetup.sh
<!--NeedCopy-->

自动化配置

对于自动化安装,请使用环境变量提供安装脚本所需的选项。如果所有必需的变量都存在,脚本将不会提示输入任何信息。

支持的环境变量包括:

  • CTX_XDL_SUPPORT_DDC_AS_CNAME = Y | N – Linux VDA 支持使用 DNS CNAME 记录指定交付控制器名称。默认设置为 N。
  • CTX_XDL_DDC_LIST = list-ddc-fqdns – Linux VDA 需要一个以空格分隔的交付控制器完全限定域名 (FQDN) 列表,用于向交付控制器注册。必须至少指定一个 FQDN 或 CNAME 别名。
  • CTX_XDL_VDA_PORT = port-number – Linux VDA 通过 TCP/IP 端口与交付控制器通信,默认端口为 80。
  • CTX_XDL_REGISTER_SERVICE = Y | N - Linux 虚拟桌面服务在计算机启动后启动。默认值为 Y。
  • CTX_XDL_ADD_FIREWALL_RULES = Y | N – Linux 虚拟桌面服务要求允许入站网络连接通过系统防火墙。您可以自动在系统防火墙中为 Linux 虚拟桌面打开所需端口(默认端口为 80 和 1494)。默认设置为 Y。
  • CTX_XDL_AD_INTEGRATION = 1 | 2 | 3 | 4 – Linux VDA 需要 Kerberos 配置设置才能向交付控制器进行身份验证。Kerberos 配置由系统上已安装和配置的 Active Directory 集成工具确定。指定要使用的受支持的 Active Directory 集成方法:
    • 1 – Samba Winbind
    • 2 – Quest Authentication Service
    • 3 – Centrify DirectControl
    • 4 – SSSD
  • CTX_XDL_HDX_3D_PRO= Y | N – Linux VDA 支持 HDX 3D Pro,这是一套 GPU 加速技术,旨在优化富图形应用程序的虚拟化。如果选择 HDX 3D Pro,则虚拟投递代理将配置为 VDI 桌面(单会话)模式 –(即 CTX_XDL_VDI_MODE=Y)。
  • CTX_XDL_VDI_MODE = Y | N – 是否将计算机配置为专用桌面交付模型 (VDI) 或托管共享桌面交付模型。对于 HDX 3D Pro 环境,请将此变量设置为 Y。此变量默认设置为 N。
  • CTX_XDL_SITE_NAME = dns-name – Linux VDA 通过 DNS 发现 LDAP 服务器。要将 DNS 搜索结果限制到本地站点,请指定 DNS 站点名称。此变量默认设置为 <none>
  • CTX_XDL_LDAP_LIST = list-ldap-servers – Linux VDA 查询 DNS 以发现 LDAP 服务器。如果 DNS 无法提供 LDAP 服务记录,您可以提供一个以空格分隔的 LDAP FQDN 列表(带 LDAP 端口)。例如,ad1.mycompany.com:389。此变量默认设置为 <none>
  • CTX_XDL_SEARCH_BASE = search-base-set – Linux VDA 通过搜索基查询 LDAP,该搜索基设置为 Active Directory 域的根(例如,DC=mycompany,DC=com)。为了提高搜索性能,您可以指定一个搜索基(例如,OU=VDI,DC=mycompany,DC=com)。此变量默认设置为 <none>
  • CTX_XDL_START_SERVICE = Y | N – Linux VDA 配置完成后,Linux VDA 服务是否启动。默认设置为 Y。

设置环境变量并运行配置脚本:

export CTX_XDL_SUPPORT_DDC_AS_CNAME=Y|N

export CTX_XDL_DDC_LIST=list-ddc-fqdns

export CTX_XDL_VDA_PORT=port-number

export CTX_XDL_REGISTER_SERVICE=Y|N

export CTX_XDL_ADD_FIREWALL_RULES=Y|N

export CTX_XDL_AD_INTEGRATION=1|2|3|4

export CTX_XDL_HDX_3D_PRO=Y|N

export CTX_XDL_VDI_MODE=Y|N

export CTX_XDL_SITE_NAME=dns-name

export CTX_XDL_LDAP_LIST=list-ldap-servers

export CTX_XDL_SEARCH_BASE=search-base-set

export CTX_XDL_START_SERVICE=Y|N

sudo -E /opt/Citrix/VDA/sbin/ctxsetup.sh
<!--NeedCopy-->

运行 sudo 命令时,键入 -E 选项以将现有环境变量传递到其创建的新 shell。Citrix 建议您使用 #!/bin/bash 作为第一行,从上述命令创建 shell 脚本文件。

或者,您可以使用单个命令指定所有参数:

sudo CTX_XDL_SUPPORT_DDC_AS_CNAME=Y|N \

CTX_XDL_DDC_LIST=list-ddc-fqdns \

CTX_XDL_VDA_PORT=port-number \

CTX_XDL_REGISTER_SERVICE=Y|N \

CTX_XDL_ADD_FIREWALL_RULES=Y|N \

CTX_XDL_AD_INTEGRATION=1|2|3|4 \

CTX_XDL_HDX_3D_PRO=Y|N \

CTX_XDL_VDI_MODE=Y|N \

CTX_XDL_SITE_NAME=dns-name \

CTX_XDL_LDAP_LIST=list-ldap-servers \

CTX_XDL_SEARCH_BASE=search-base-set \

CTX_XDL_START_SERVICE=Y|N \

/opt/Citrix/VDA/sbin/ctxsetup.sh
<!--NeedCopy-->

删除配置更改

在某些情况下,您可能必须删除由 ctxsetup.sh 脚本进行的配置更改,而无需卸载 Linux VDA 软件包。

在继续操作之前,请查看有关此脚本的帮助:

sudo /usr/local/sbin/ctxcleanup.sh --help
<!--NeedCopy-->

要删除配置更改:

sudo /usr/local/sbin/ctxcleanup.sh
<!--NeedCopy-->

重要:

此脚本会删除数据库中的所有配置数据,并使 Linux VDA 无法运行。

配置日志

ctxsetup.shctxcleanup.sh 脚本会在控制台上显示错误,并将其他信息写入配置日志文件:

/tmp/xdl.configure.log

重新启动 Linux VDA 服务以使更改生效。

步骤 6:运行 Linux VDA

使用 ctxsetup.sh 脚本配置 Linux VDA 后,您可以运行以下命令来控制 Linux VDA。

启动 Linux VDA:

要启动 Linux VDA 服务:

sudo /sbin/service ctxhdx start

sudo /sbin/service ctxvda start
<!--NeedCopy-->

停止 Linux VDA:

要停止 Linux VDA 服务:

sudo /sbin/service ctxvda stop

sudo /sbin/service ctxhdx stop
<!--NeedCopy-->

重新启动 Linux VDA:

要重新启动 Linux VDA 服务:

sudo /sbin/service ctxvda stop

sudo /sbin/service ctxhdx restart

sudo /sbin/service ctxvda start
<!--NeedCopy-->

检查 Linux VDA 状态:

要检查 Linux VDA 服务的运行状态:

sudo /sbin/service ctxvda status

sudo /sbin/service ctxhdx status
<!--NeedCopy-->

步骤 7:在 XenApp 或 XenDesktop® 中创建计算机目录

创建计算机目录和添加 Linux VDA 计算机的过程与传统 Windows VDA 方法类似。有关如何完成这些任务的更详细说明,请参阅创建计算机目录管理计算机目录

对于创建包含 Linux VDA 计算机的计算机目录,存在一些限制,这些限制使该过程与为 Windows VDA 计算机创建计算机目录的过程有所不同:

  • 对于操作系统,请选择:
    • 用于托管共享桌面交付模型的“服务器操作系统”选项。
    • 用于 VDI 专用桌面交付模型的“桌面操作系统”选项。
  • 确保计算机设置为未进行电源管理。
  • 由于 Linux VDA 不支持 MCS,因此请选择 PVS其他服务或技术(现有映像)部署方法。
  • 请勿在同一计算机目录中混合使用 Linux 和 Windows VDA 计算机。

注意:

早期版本的 Citrix Studio 不支持“Linux 操作系统”的概念。但是,选择“Windows 服务器操作系统”或“服务器操作系统”选项意味着等效的托管共享桌面交付模型。选择“Windows 桌面操作系统”或“桌面操作系统”选项意味着每台计算机一个用户的交付模型。

提示:

如果您将计算机从 Active Directory 域中删除并重新加入,则必须再次从计算机目录中删除并添加该计算机。

步骤 8:在 XenApp® 或 XenDesktop 中创建交付组

创建交付组和添加包含 Linux VDA 计算机的计算机目录的过程与 Windows VDA 计算机几乎相同。有关如何完成这些任务的更详细说明,请参阅创建交付组

对于创建包含 Linux VDA 计算机目录的交付组,适用以下限制:

  • 对于交付类型,请选择“桌面”或“应用程序”。

  • 确保选定的 AD 用户和组已正确配置,可以登录到 Linux VDA 计算机。
  • 不允许未经身份验证(匿名)的用户登录。
  • 请勿将交付组与包含 Windows 计算机的计算机目录混合使用。

重要提示:

发布应用程序从 Linux VDA 1.4 版及更高版本开始受支持。但是,Linux VDA 不支持将桌面和应用程序交付到同一台计算机。