Performance

La bibliothèque cliente PHP facilite les interactions avec l'API Google Ads avec une configuration minimale de votre part. Cependant, les performances dépendent fortement de la manière dont la bibliothèque est utilisée et intégrée.

La plupart de ces bonnes pratiques s'appliquent à tous les langages. Ce guide présente ceux qui sont spécifiques à PHP.

Implémentation de tampons de protocole

Protobuf est utilisé par gRPC et l'API Google Ads pour les messages de demande et de réponse. Deux implémentations sont disponibles, bien que celle écrite en C offre les meilleures performances.

Pour en savoir plus, consultez le guide Protobuf.

Mode de fonctionnement de l'interpréteur PHP

PHP est un langage de script polyvalent et comporte de nombreux modes d'opération en fonction de l'utilisation. Le langage PHP (Common Gateway Interface) présente un avantage notable, car il peut partager des ressources entre les exécutions.

Version de PHP

Il est recommandé de passer régulièrement à une version de PHP plus récente, car elle offre généralement de meilleures performances globales. Liste des versions PHP compatibles

Versions inutilisées de l'API Google Ads

Toutes les versions de la bibliothèque cliente sont compatibles avec plusieurs versions de l'API Google Ads. Des packages spécifiques sont disponibles pour chaque version de l'API Google Ads compatible avec la bibliothèque cliente.

Les packages dédiés aux versions de l'API Google Ads qui ne sont pas utilisées peuvent être supprimés de la bibliothèque cliente en toute sécurité. Étant donné qu'il peut être utile d'accélérer l'exécution ou de réduire l'espace mémoire utilisé, la bibliothèque cliente fournit des utilitaires permettant d'effectuer cette opération de manière automatisée.

Exemple

Supposons que vous implémentiez la bibliothèque cliente qui n'utilise que la dernière version de l'API (v17) et que vous souhaitiez supprimer la prise en charge des versions inutilisées de l'API : v16 et v15.

Dans le fichier composer.json du projet, définissez un script Composer (nommé remove-google-ads-api-version-support) qui exploite l'utilitaire fourni par la bibliothèque cliente, dans la classe ApiVersionSupport:

"scripts": {
  "remove-google-ads-api-version-support": [
    "Google\\Ads\\GoogleAds\\Util\\ApiVersionSupport::remove"
  ]
}

Ensuite, utilisez le script Composer avec les numéros de version comme paramètres et imprimez des messages d'état:

# Change the current directory to the project directory.
cd /path/to/the/project

# Install the project.
composer install

# Output the vendor folder size and the list of Google Ads API versions that are
# supported before removing support for Google Ads API versions.
echo "# Supported Google Ads API versions:"
find ./vendor/googleads/google-ads-php/src/Google/Ads/GoogleAds/V* -maxdepth 0 | grep -o '..$'
echo "# Vendor folder size:"
du -sh ./vendor

# Use the Composer script to remove the unused versions v15 and v16 of the Google Ads API.
echo "# Removing support..."
composer run-script remove-google-ads-api-version-support -- 15 16

# Output the vendor folder size and the list of Google Ads API versions that are
# supported after removing support for Google Ads API versions.
echo "# Supported Google Ads API versions:"
find ./vendor/googleads/google-ads-php/src/Google/Ads/GoogleAds/V* -maxdepth 0 | grep -o '..$'
echo "# Vendor folder size:"
du -sh ./vendor

L'exemple de résultat d'exécution ci-dessous indique une réduction de la taille du fichier de 50 Mo et la seule version compatible restante est V17:

# Supported Google Ads API versions:
V15
V16
V17
# Vendor folder size:
110M    ./vendor
# Removing support...
> Google\Ads\GoogleAds\Util\ApiVersionSupport::remove
Removing support for the version 15 of Google Ads API...
Done
Removing support for the version 16 of Google Ads API...
Done
# Supported Google Ads API versions:
V17
# Vendor folder size:
60M     ./vendor

Développement ou production

PHP est un langage interprété dans le sens où il compile d'abord les instructions avant de les exécuter. Cela est généralement avantageux, car pendant le développement, les sources changent souvent, tandis que le temps d'exécution n'est pas si crucial. Toutefois, c'est l'inverse qui se produit au moment de la production, car la stabilité et les performances deviennent les principales préoccupations.

Cache

La mise en cache est courante et vivement recommandée, car elle améliore les performances et augmente la stabilité en stockant des instructions de script précompilées.

Disponible par défaut, OPcache est la solution la plus couramment utilisée.

Réapprovisionnement automatique

Le chargement automatique est courant, car il améliore les performances et augmente la stabilité en chargeant des informations précompilées sur les classes.

La bibliothèque cliente PHP est conforme à la norme PSR-4 pour le chargement automatique et fournit la définition dans le fichier composer.json. Les options dédiées de Composer, telles que --optimize-autoloader ou --classmap-authoritative, par exemple, peuvent ensuite être utilisées telles quelles.

Journalisation

Définir les enregistreurs sur un niveau élevé comme ERROR peut aider à réduire les frais généraux liés au temps d'exécution et la consommation de mémoire.

Pour en savoir plus, consultez le guide de journalisation.

Débogage et profilage

Nous vous recommandons de désactiver les outils de débogage et de profileur, car ils entraînent généralement une surcharge du temps d'exécution.

Précharger

Depuis PHP 7.4, le préchargement OPcache peut être utilisé pour précharger des scripts en mémoire, allant plus loin que la mise en cache standard.

Un script doit être conçu pour tirer parti de cette fonctionnalité, mais ce n'est pas le cas de la bibliothèque cliente PHP, car il n'existe aucun moyen générique d'implémenter le préchargement OPcache. Le compromis entre utilisation de la mémoire et gain de performances est très spécifique à un projet et à une exécution donnés.