Bonnes pratiques relatives aux interactions interaction-best-practices

Recommandations générales general-recommendations

Une gestion des offres efficace dans Adobe Campaign requiert une attention toute particulière. Pour éviter tout problème, vous devez trouver le juste milieu entre le nombre de contacts et le nombre de catégories d'offres et le nombre d'offres.

Cette section présente les bonnes pratiques pour gérer le module nteraction dans Adobe Campaign, y compris les règles d'éligibilité, les filtres prédéfinis, les activités de workflow et les options de bases de données.

  • Lors de l'implémentation et de la configuration des interactions, vous devez tenir compte des recommandations suivantes :

    • Dans le cas du moteur batch (généralement utilisé dans les communications sortantes, telles que les emails), le débit est la préoccupation centrale, car plusieurs contacts peuvent être gérés simultanément. Le goulot d'étranglement typique est la performance de la base de données.
    • La principale contrainte du moteur unitaire (généralement utilisé dans les communications entrantes, telles qu'une bannière sur un site web) est la latence, car quelqu'un attend une réponse. Le goulot d'étranglement typique est la performance de l'unité centrale.
    • La conception du catalogue d'offres a un impact considérable sur la performance d'Adobe Campaign.
    • Lorsque vous travaillez avec un nombre élevé d'offres, il est recommandé de les diviser en plusieurs catalogues d'offres.
  • Retrouvez ci-dessous quelques bonnes pratiques relatives à l'utilisation des règles d'éligibilité  :

    • Simplifiez les règles. La complexité des règles a une incidence sur la performance, car elle prolonge la recherche. Une règle est complexe si elle comprend plus de cinq conditions.
    • Afin d'accroître la performance, les règles peuvent être décomposées en différents filtres prédéfinis partagés entre des offres multiples.
    • Placez les règles de catégorie d'offres les plus restrictives à la position la plus élevée possible dans l'arbre. De cette manière, elles excluront le plus grand nombre de contacts en premier, ce qui réduit le nombre de cibles et empêche leur traitement par d'autres règles.
    • Placez les règles les plus coûteuses en termes de temps ou de traitement en bas de l'arbre. De cette façon, ces règles seront uniquement exécutées sur l'audience cible restante.
    • Démarrez au niveau d'une catégorie spécifique afin d'éviter d'analyser l'ensemble de l'arbre.
    • Pour économiser le temps de traitement, précalculez les agrégats au lieu de créer des règles complexes avec des jointures. Pour ce faire, essayez de stocker les données client dans une table de référence qui peut être consultée au sein des règles d'éligibilité.
    • Utilisez un nombre minimum de poids pour limiter le nombre de requêtes.
    • Il est recommandé de disposer d'un nombre limité d'offres par emplacement d'offre. Cela accélère la récupération des offres dans n'importe quel emplacement donné.
    • Servez-vous d'index, en particulier pour les colonnes de recherche fréquemment utilisées.
  • Vous trouverez ci-dessous quelques bonnes pratiques concernant la table de proposition  :

    • Utilisez un nombre minimum de règles pour que le traitement soit le plus rapide possible.
    • Limitez le nombre d'enregistrements dans la table de propositions : conservez uniquement les enregistrements requis pour contrôler la mise à jour de son statut et ce que requièrent les règles, puis archivez-les dans un autre système.
    • Réalisez une maintenance de base de données intensive sur la table de propositions, par exemple, en reconstruisant les index ou en recréant la table.
    • Limitez le nombre de propositions par cible. N'en définissez pas davantage par rapport à ce que vous allez utiliser.
    • Dans la mesure du possible, évitez les jointures dans les critères des règles.

Conseils pour la gestion des offres tips-managing-offers

Cette section contient des conseils plus détaillés sur la gestion des offres et l'utilisation du module Interaction dans Adobe Campaign.

Plusieurs emplacements dans un e-mail multiple-offer-spaces

Lorsque vous incluez des offres dans des diffusions, elles sont généralement sélectionnées en amont dans le workflow Campaign par le biais d'une activité de workflow Enrichissement (ou d'une autre activité similaire).

Lors de la sélection des offres dans une activité Enrichissement, vous pouvez choisir l'emplacement à utiliser. Cependant, quel que soit l'emplacement sélectionné, le menu de personnalisation de la diffusion dépend de l'espace d'offre configuré dans la diffusion.

Dans l'exemple ci-dessous, l'emplacement d'offre sélectionné dans la diffusion est Email (Environnement - Destinataire):

Si l'emplacement d'offre sélectionné dans la diffusion ne dispose pas d'une fonction de rendu HTML configurée, vous ne la verrez pas dans le menu de diffusion et elle ne sera pas disponible pour pouvoir le sélectionner. Cette situation est indépendante de l'emplacement sélectionné dans l'activité Enrichissement.

Dans l'exemple ci-dessous, la fonction de rendu HTML est disponible dans la liste déroulante, car l'emplacement d'offre sélectionné dans la diffusion comporte une fonction de rendu :

Cette fonction insère du code tel que : <%@ include proposition="targetData.proposition" view="rendering/html" %>.

Lorsque vous sélectionnez la proposition, la valeur de l'attribut vue est la suivante :

  • "render/html" : rendu HTML. Il utilise la fonction de rendu HTML.
  • "offer/view/html" : contenu HTML. Il n'utilise pas la fonction de rendu HTML et n'inclut que le champ HTML.

Lorsque vous incluez plusieurs emplacements d'offre dans une diffusion par email unique alors que seuls certains d'entre eux ont des fonctions de rendu, vous devez vous rappeler des offres et des emplacements d'offre correspondants, et dans ces emplacements, ceux dotés de fonctions de rendu.

Pour éviter tout problème, il est donc recommandé de définir une fonction de rendu HTML pour tous les emplacements d'offre, même si le vôtre ne nécessite que du contenu HTML.

Définition du rang dans la table du log des propositions rank-proposition-log-table

Les emplacements d'offre permettent de stocker des données dans la table des propositions après génération ou acceptation de propositions :

Toutefois, cela ne s'applique qu'aux interactions entrantes.

Il est également possible de stocker des données supplémentaires dans la table des propositions si vous utilisez les interactions sortantes, ou les offres sortantes sans le module Interaction.

Un champ de la table temporaire de workflow dont le nom correspond à celui d'un champ de la table des propositions est copié dans le même champ de la table des propositions.

Par exemple, en cas de sélection manuelle d'une offre (sans le module Interaction) dans une activité de workflow Enrichissement, les champs standard sont définis comme suit :

Il est possible d'ajouter d'autres champs, par exemple un champ @rank :

Puisqu'il existe un champ appelé @rank dans la table des propositions, la valeur contenue dans la table temporaire du workflow sera copiée.

Pour plus d'informations sur le stockage de champs supplémentaires dans la table des propositions, consultez cette section.

Pour les offres sortantes avec le module Interaction, cette possibilité est utile lorsque plusieurs offres sont sélectionnées et que vous souhaitez enregistrer l'ordre dans lequel elles seront affichées dans un email.

Vous pouvez également stocker des métadonnées supplémentaires directement dans la table des propositions, par exemple le niveau de dépense actuel, pour conserver des historiques enregistrés relatifs aux dépenses au moment de la génération des offres.

En cas d'utilisation d'une interaction sortante, il est possible d'ajouter le champ @rank comme dans l'exemple ci-dessus. Cependant, sa valeur est automatiquement définie en fonction de l'ordre renvoyé par le module Interaction. Par exemple, si vous utilisez le module Interaction pour sélectionner trois offres, les valeurs 1, 2 et 3 sont renvoyées dans le champ @rank.

Lorsque vous utilisez le module Interaction et que vous sélectionnez manuellement des offres, l'utilisateur peut combiner les deux approches. Par exemple, l'utilisateur peut définir manuellement le champ @rank sur 1 pour l'offre sélectionnée manuellement et utiliser une expression telle que "1 + @rank" pour les offres renvoyées par le module Interaction. En supposant que le module Interaction sélectionne trois offres, les offres renvoyées par les deux approches seront classées de 1 à 4 :

Extension du schéma nms:offer extending-nms-offer-schema

Lors de l'extension du schéma nms:offer, veillez à suivre la structure prête à l'emploi déjà configurée :

  • Définissez un nouveau champ pour le stockage du contenu sous <element name="view">.

  • Un nouveau champ doit être défini deux fois. Une fois sous forme de champ XML normal, et une autre fois sous forme de champ XML CDATA en ajoutant "_jst" au nom. Par exemple :

    code language-none
    <element label="Price" name="price" type="long" xml="true"/>
    <element advanced="true" label="Script price" name="price_jst" type="CDATA" xml="true"/>
    
  • Un champ contenant des URL à tracker doit être placé sous <element name="trackedUrls">, lequel se trouve sous <element name="view" >.

recommendation-more-help
35662671-8e3d-4f04-a092-029a056c566b