Optimisation du SDK de communications unifiées
Introduction
Citrix Virtual Apps and Desktops vous permet de fournir des applications à vos utilisateurs sur une grande variété de périphériques de point de terminaison. Bon nombre de ces applications incluent des fonctionnalités de communication en temps réel (RTC), telles que les conférences audio et vidéo. Cependant, des défis peuvent survenir lors de la livraison de ces applications dans un environnement virtualisé. Les méthodes de livraison traditionnelles acheminent les flux multimédias (audio/vidéo) de l’appareil client vers le serveur VDI dans le centre de données avant de les renvoyer au point de terminaison. Ce « hairpinning » introduit un trafic et une surcharge de traitement inutiles sur le serveur, en particulier pour les appels audio et vidéo gourmands en bande passante.
Le SDK de communications unifiées Citrix (UCSDK) est une technologie qui permet aux fournisseurs de technologies d’optimiser ces applications RTC pour une utilisation dans les environnements Citrix. Lorsqu’une application est optimisée, elle peut offrir une expérience utilisateur qui égale ou même dépasse celle de l’application exécutée sur un bureau local. Dans le monde d’aujourd’hui, une communication en temps réel transparente est essentielle pour la productivité et la collaboration. Lors de l’utilisation d’applications dans un environnement virtuel, il est crucial que les appels audio et vidéo, le partage d’écran et les autres fonctionnalités de communication fonctionnent aussi fluidement que sur un bureau local. Les applications optimisées offrent cette expérience.
Cette documentation produit détaille tout ce qui est nécessaire aux clients Citrix pour apprendre à déployer et à utiliser les applications optimisées par UCSDK.
Fonctionnement
Citrix propose une méthode de livraison optimisée pour les applications de communication en temps réel au sein des VDI. Cette approche s’appuie sur le SDK de communications unifiées (UCSDK) pour diviser l’application virtualisée en deux parties :
- Interface utilisateur (UI) : L’interface utilisateur reste au sein de l’hôte virtuel, affichée de manière transparente dans le bureau virtuel ou la fenêtre de l’application.
- Moteur multimédia : Les tâches de traitement multimédia (encodage/décodage audio et vidéo) sont déchargées sur l’appareil local de l’utilisateur. Cela minimise la charge du serveur et optimise l’utilisation du réseau.
Généralement, Citrix propose le UCSDK aux fournisseurs de technologies dans le domaine des communications en temps réel et collabore avec eux pour intégrer le UCSDK dans ces applications. Une fois intégré, tout client Citrix utilisant une application optimisée par UCSDK bénéficiera d’une expérience améliorée. Le UCSDK Citrix peut également être utilisé par les clients Citrix dans les cas où une application interne personnalisée est en cours de développement. Dans la plupart des cas, cependant, les clients n’ont pas besoin d’utiliser et de développer avec le UCSDK ; ils doivent simplement configurer l’environnement Citrix et l’application pour obtenir une expérience optimisée.
Remarque :
Les références au SDK WebRTC Citrix (ou) à une application optimisée HDX™ indiquent une intégration avec le UCSDK Citrix et peuvent être utilisées de manière interchangeable.
Nouveautés
UCSDK 4.1.0 est la dernière version généralement disponible que les fournisseurs de technologies peuvent intégrer. De plus, deux autres versions sont prises en charge : UCSDK 4.0.2 et UCSDK 3.1.0. De nouvelles fonctionnalités sont introduites avec les versions du UCSDK et les fournisseurs de technologies doivent s’assurer de mettre à niveau le SDK afin que les clients puissent bénéficier de ces fonctionnalités. De cette façon, les clients Citrix peuvent se concentrer uniquement sur la mise à niveau des composants Citrix nécessaires pour obtenir les nouvelles fonctionnalités.
Avec la publication de UCSDK 4.1.0, nous introduisons des améliorations critiques de l’expérience utilisateur et de toutes nouvelles fonctionnalités qui permettront une intégration plus poussée avec les produits des partenaires et une plus grande valeur pour nos clients.
Nouvelles fonctionnalités
- Enregistrement d’écran du point de terminaison UCSDK (préversion technique) : Comblant une lacune majeure dans l’enregistrement de conformité, les nouvelles API UCSDK peuvent désormais capturer du contenu sur le point de terminaison, même lorsque les applications s’exécutent au sein d’un VDI. Cette fonctionnalité, actuellement en préversion pour les points de terminaison Windows, permet aux fournisseurs de technologies d’améliorer leurs applications pour prendre en charge l’enregistrement d’écran du point de terminaison sur Citrix. Notez que cette fonctionnalité vise à améliorer les applications des fournisseurs et est différente de l’enregistrement de session Citrix.
- Gestion de la reconnexion de session : Une amélioration critique de Bootstrap améliore considérablement l’expérience des applications de navigateur, la rapprochant de celle des applications de bureau basées sur Electron. Les applications basées sur un navigateur utilisant Bootstrap peuvent désormais gérer dynamiquement les déconnexions de session Citrix, offrant une expérience utilisateur transparente aux utilisateurs finaux.
-
Prise en charge de nouvelles méthodes : Ajout de la prise en charge du redémarrage de la collecte ICE et de la prise en charge de
iceCandidatePoolSizedansRTCConfiguration. -
Meilleure gestion des erreurs et améliorations de la conformité : Conformité améliorée à la spécification WebRTC pour
getUserMedia. Amélioration degetStats()pourCitrixPeerConnection,RtpSenderetRtpReceiverafin de renvoyer un rapport vide au lieu devoiden cas d’erreur.
Les versions entièrement compatibles avec UCSDK 4.1.0 incluent :
- Citrix Virtual Apps and Desktops™ 2503
- Citrix Workspace™ App pour Windows 2503
- Citrix Workspace App pour Mac 2503
- Citrix Workspace App pour Linux 2503
- La dernière version de ChromeOS/HTML5.
Remarque :
Les clients Citrix peuvent contacter les fournisseurs de technologie pour mettre à niveau le SDK ou ajouter la prise en charge de fonctionnalités spécifiques si des cas d’utilisation peuvent être réalisés avec les fonctionnalités nouvellement introduites.
Avantages clés
Lorsque vous utilisez des applications optimisées avec le SDK Citrix UC, vous pouvez vous attendre à :
- Des performances de traitement multimédia améliorées en déchargeant l’encodage/décodage multimédia gourmand en processeur de l’agent de livraison virtuel (VDA) Citrix vers le point de terminaison client, augmentant ainsi la réactivité globale pour les utilisateurs finaux.
- Une réduction de l’utilisation du CPU et de la bande passante sur le VDA Citrix, permettant aux services informatiques de prendre en charge davantage d’utilisateurs simultanés par hôte et aux entreprises de faire évoluer les déploiements de bureaux virtuels Citrix de manière rentable.
- Un coût total de possession réduit pour les entreprises, car les points de terminaison optimisés prolongent la durée de vie des bureaux virtuels existants et réduisent les besoins en infrastructure hôte, ce qui diminue les dépenses d’investissement et les coûts d’exploitation au fil du temps.
- La prise en charge des plateformes de points de terminaison Windows, Mac, Linux, ChromeOS et HTML5.
Cas d’utilisation
Le SDK UC est conçu pour optimiser les applications de communication en temps réel qui respectent la norme WebRTC. Voici les scénarios clés et les types d’applications basées sur WebRTC qui peuvent utiliser ou utilisent déjà le SDK UC.
-
Centre de contact en tant que service (CCaaS) / Plateformes de centre de contact cloud : Gèrent principalement les interactions client sur plusieurs canaux, optimisant les flux de travail des agents.
- Exemples : Amazon Connect, Twilio, Avaya Experience Platform, Talkdesk, Content Guru
-
Communications unifiées en tant que service (UCaaS) / Communications d’entreprise cloud : Intègrent la voix, la vidéo, la messagerie d’équipe et la présence pour une communication d’entreprise complète.
- Exemples : Ring Central, 8x8, Intermedia, Alcatel-Lucent Rainbow
-
Plateforme de communication en tant que service (CPaaS) : Fournissent des API pour intégrer des capacités de communication en temps réel directement dans des applications personnalisées.
- Exemples : Twilio, Ribbon Communications
-
Vidéoconférence et collaboration d’entreprise : Plateformes dédiées aux réunions vidéo de haute qualité, à la conférence et aux fonctionnalités de collaboration avancées.
- Exemple : Pexip
-
Communications pour le trading financier : Conçues pour les besoins de communication uniques, haute performance et conformes des marchés financiers.
- Exemple : IPC Unigy
-
Plateformes d’apprentissage et de formation virtuelles : Conçues pour des expériences interactives et de haute qualité en classe virtuelle et en formation.
- Exemple : Vitero
La fondation WebRTC sous-jacente du SDK Citrix UC signifie que ses capacités d’optimisation peuvent s’étendre à toutes les applications de communication basées sur WebRTC. Cela ouvre la voie à l’optimisation d’un large éventail d’applications qui utilisent WebRTC pour les interactions en temps réel, même si elles ne sont pas actuellement répertoriées comme optimisées avec le SDK UC. Nous encourageons les clients à contacter Citrix pour tout cas d’utilisation ou application qu’ils souhaitent voir optimisé.
Architecture du SDK UC

-
Application du fournisseur : Il peut s’agir de toute application de communication en temps réel tierce, basée sur un bureau ou un navigateur, qui a intégré le SDK UC.
-
UCSDK JS : UCSDK JS fournit les API que les applications des fournisseurs utilisent pour décharger l’audio/vidéo vers le point de terminaison.
-
HdxRtcEngine : Il s’agit du moteur multimédia WebRTC intégré à Citrix Workspace App qui traite et gère l’appel audio/vidéo déchargé.
Une fois le SDK chargé et utilisé, le processus HdxRtcEngine.exe est lancé sur le point de terminaison client si la redirection réussit. Une fois HdxRtcEngine.exe lancé sur le point de terminaison client, toutes les données de signalisation et de charge utile circulent du VDA Citrix vers le point de terminaison client, atteignent le cloud, reviennent au point de terminaison client, puis sont transmises au VDA. Par exemple, un aller-retour complet du flux pourrait être :
Application du fournisseur -> SDK CitrxWebrtc.js -> Composants VDA Citrix -> Composants du point de terminaison client Citrix -> Cloud -> Composants du point de terminaison client Citrix -> Composants VDA Citrix -> SDK CitrxWebrtc.js -> Application du fournisseur
Configuration système requise
La configuration système requise indique les différentes versions des composants Citrix nécessaires avec la dernière version du SDK UC - 4.1.0. Pour plus de détails sur la compatibilité des anciennes versions du SDK et les exigences spécifiques des fonctionnalités, consultez le tableau Versions et matrice des fonctionnalités ci-dessous.
Remarque :
Pour que les clients puissent utiliser toute fonctionnalité ajoutée au SDK UC, assurez-vous que l’application du fournisseur a intégré la version appropriée du SDK UC et activé la fonctionnalité, et utilisez les versions appropriées de VDA et CWA dans votre environnement.
Versions entièrement compatibles
Les versions entièrement compatibles indiquent qu’en utilisant ces versions des composants Citrix avec la dernière version de l’UCSDK, les clients peuvent profiter de toutes les fonctionnalités disponibles. Pour la dernière version actuelle de l’UCSDK (4.1.0), les versions entièrement compatibles des composants Citrix sont les suivantes :
- Citrix Virtual Apps™ and Desktops : 2503
- Citrix Workspace App Windows : 2503
- Citrix Workspace App Mac : 2503
- Citrix Workspace App Linux : 2503
- Citrix Workspace App ChromeOS/HTML5 : Dernière version
Configuration
La fonctionnalité de l’UCSDK dépend de trois facteurs : la version de l’UCSDK que le fournisseur a intégrée et les fonctionnalités qu’il a activées, la version de Citrix Virtual Apps and Desktops et la version de l’application Citrix Workspace utilisée.
Côté Citrix, assurez-vous que les éléments suivants sont configurés afin que l’application optimisée puisse être optimisée :
- Assurez-vous que la stratégie de redirection Microsoft Teams est activée. Pour plus d’informations, reportez-vous à la section Paramètres de stratégie multimédia. Notez que cette stratégie est activée par défaut.
- Les applications tierces basées sur Electron ou sur un navigateur qui utilisent le SDK
CitrixWebrtc.jsne sont pas prises en charge par défaut. Le serviceCtxHdxWebSocketService(WebSocketService.exe) n’autorisera pas les connexions provenant d’applications qui ne figurent pas sur la liste d’autorisation. Le nom de l’exécutable binaire de l’application souhaitée doit être ajouté à une clé de registre de liste blanche.
Sur le VDA
- Créer un chemin de clé :
HKLM\Software\WOW6432Node\Citrix\WebSocketService - Nom de la clé :
ProcessWhitelist - Type :
MULTISZ - Valeur de la clé :
Mytestapp.exe
Si vous avez plusieurs applications, saisissez chaque application sur une nouvelle ligne. Ne copiez pas et ne collez pas à partir d’un fichier texte et n’insérez pas de virgules. Assurez-vous que le nom fourni correspond au nom de l’exécutable de l’application. Cette valeur de registre n’est pas sensible à la casse.
Si l’application est accessible via un navigateur au lieu d’une application de bureau complète, vous devez autoriser, par exemple, chrome.exe dans la valeur de registre.
Une fois le registre ci-dessus configuré avec succès, redémarrez le VDA ou redémarrez CtxHdxWebSocketService pour terminer la configuration de la liste blanche.
Sur le client
Aucune configuration n’est nécessaire. Installez simplement l’application Citrix Workspace.
Chaque fournisseur peut avoir un nom d’application très spécifique. Par conséquent, reportez-vous à la documentation du fournisseur liée dans la section Prise en charge actuelle des fournisseurs pour déterminer quel nom d’application doit être autorisé dans le WebSocketService.
Référence des fonctionnalités
Découpage de superposition optimisé pour des performances et une expérience utilisateur améliorées
À partir de CVAD 2511, le mécanisme de gestion des superpositions vidéo redirigées dans des fonctionnalités telles que l’optimisation HDX Microsoft Teams et l’optimisation UCSDK a été repensé pour améliorer à la fois l’expérience utilisateur et les performances du serveur.
Avantages essentiels
-
Précision visuelle améliorée : Cette amélioration résout les problèmes d’affichage où les éléments d’application, tels que les menus contextuels ou les notifications, apparaissaient incorrectement derrière le contenu vidéo. La nouvelle logique garantit que tous les composants sont rendus dans le bon ordre, offrant une expérience plus fluide et prévisible.
-
Performances améliorées : Cette optimisation réduit considérablement l’utilisation du processeur sur le Virtual Delivery Agent. En remplaçant les anciennes méthodes d’interrogation gourmandes en ressources par une approche plus efficace basée sur les graphiques, cette modification améliore l’évolutivité du serveur et permet une densité d’utilisateurs plus élevée.
Remarque :
La fonctionnalité dépend d’une future version de Microsoft Teams (ou d’une autre application partenaire UCSDK) et nécessite Citrix Workspace App pour Windows 2511.
Versions et matrice des fonctionnalités
Étant donné que les mises à jour de version sont fréquentes, veuillez consulter les pages de cycle de vie des produits Citrix Virtual Apps and Desktops et Citrix Workspace app pour vous assurer qu’une version particulière est prise en charge. Pour de nombreuses fonctionnalités plus anciennes, les versions mentionnées dans le tableau sont les dernières versions de Current Release (CR) prises en charge au moment de la rédaction de ce document.
| Fonctionnalité | Version UCSDK | VDA | CWA Windows | CWA Mac | CWA Linux | CWA ChromeOS/HTML5 | |—————————-|————-|———|———–|———————|———————-|—————————————————————————–| | Audio / Vidéo (p2p et conférence) | 3.1.0 | 2203 LTSR Latest CU / 2311 CR | 2402 LTSR Latest CU / 2311 CR | 2311 | 2311 | 2312 | | Partage d’écran | 3.1.0 | 2203 LTSR Latest CU / 2311 CR | 2402 LTSR Latest CU / 2311 CR | 2311 | 2311 | 2312 | | DTMF | 3.1.0 | 2203 LTSR Latest CU / 2311 CR | 2402 LTSR Latest CU / 2311 CR | 2311 | 2311 | 2312 | | Prise en charge du serveur proxy | 3.1.0 | 2203 LTSR Latest CU / 2311 CR | 2402 LTSR Latest CU / 2311 CR | 2311 | 2311 | 2312 | | Partage d’applications | 3.1.0 | 2203 LTSR Latest CU / 2311 CR | 2402 LTSR Latest CU / 2311 CR | 2311 | 2311 | N/A | | e911 dynamique | 3.1.0 | 2203 LTSR Latest CU / 2311 CR | 2402 LTSR Latest CU / 2311 CR | 2311 | 2311 | 2312 | | Multi-fenêtre | 3.1.0 | 2203 LTSR Latest CU / 2311 CR | 2402 LTSR Latest CU / 2311 CR | 2311 | 2311 | 2312 | | Prise en charge du plan unifié SDP | 3.1.0 | 2203 LTSR Latest CU / 2311 CR | 2402 LTSR Latest CU / 2311 CR | 2311 | 2311 | 2312 | | Résolution de flux / Simulcast | 3.1.0 | 2203 LTSR Latest CU / 2311 CR | 2402 LTSR Latest CU / 2311 CR | 2311 | 2311 | 2312 | | Audio à distance (avec boucle) | 3.1.0 | 2203 LTSR Latest CU / 2311 CR | 2402 LTSR Latest CU / 2311 CR | 2311 | 2311 | 2405 | | UCSDK basé sur navigateur (prise en charge du démarrage) | 4.0.2 | 2407 CR | 2402 LTSR Latest CU / 2311 CR | 2311 | 2311 | 2312 | | API Web HID | 4.0.2 | 2203 LTSR Latest CU / 2311 CR | 2409.10 | 2411 | 2411 | 2505 | | API Web Audio | 4.0.2 | 2203 LTSR Latest CU / 2311 CR | 2405 | 2405 | 2405 | N/A | | Redémarrage ICE | 4.1.0 | 2203 LTSR Latest CU / 2311 CR | 2503.2 | 2503 | 2503 | 2502.10 | | Enregistrement d’écran (Aperçu)¹ | 4.1.0 | 2503 | 2503.2 | N/A | N/A | N/A |
Remarque :
Nous avons introduit une nouvelle politique pour l’enregistrement d’écran, vous avez donc besoin de la version 2503 du contrôleur de livraison™, qui est fournie avec CVAD 2503.
Prise en charge actuelle des fournisseurs
Plusieurs fournisseurs tiers ont intégré le SDK Unified Communications dans leurs produits. La liste actuelle des fournisseurs et de leur documentation de support est présentée ci-dessous :
| Fournisseur | Documentation |
|---|---|
| Sprinklr | |
| Microsoft Dynamics 365 | Dynamics 365 Contact Center Documentation |
| Amazon Connect | Optimize Amazon Connect audio for Citrix cloud desktops |
| Ring Central | Using RingCentral in a Citrix VDI environment |
| Five9 | Five9 WebRTC in Citrix Environments |
| Twilio | Twilio Flex on Citrix VDI |
| Avaya | Avaya Experience Platform Public Cloud VDI solution for Citrix |
| 8x8 | Citrix VDI Integration with 8x8 Work for Desktop & Web |
| Content Guru | Content Guru Citrix Integration |
| Ribbon Communications | Ribbon Communications Citrix WebRTC SDK |
| Intermedia | Installing Intermedia Unite on Citrix Virtual Apps and Desktops |
| Alcatel-Lucent Rainbow | Citrix Optimization for Rainbow Desktop Application |
| Talkdesk | Talkdesk Agent Workspace VDI Connect |
| IPC | IPC Unigy Soft Client Citrix VDI |
| Vitero | Vitero Inspire for Citrix VDI |
| Pexip | Deploying Connect desktop app in Citrix Pexip Infinity Docs |
Dépannage
Pour plus d’informations sur le dépannage, consultez Conseils de dépannage pour les applications optimisées avec le SDK Citrix Unified Communications.
Problèmes connus et limitations
Cette section documentera les problèmes connus et les limitations actuels tels qu’ils sont identifiés.
Dans cet article
- Introduction
- Fonctionnement
- Nouveautés
- Avantages clés
- Cas d’utilisation
- Architecture du SDK UC
- Configuration système requise
- Versions entièrement compatibles
- Configuration
- Référence des fonctionnalités
- Versions et matrice des fonctionnalités
- Prise en charge actuelle des fournisseurs
- Dépannage
- Problèmes connus et limitations