PHP 客户端库可简化与 Google Ads API 的互动,您只需进行最少的配置。不过,性能在很大程度上取决于库的使用和集成方式。
这些最佳实践中的大多数都适用于所有语言。本指南将介绍 PHP 特有的扩展。
Protobuf 实现
Protobuf 由 gRPC 和 Google Ads API 用于请求和响应消息。虽然有两种实现方式,但以 C 语言编写的实现方式性能更好。
如需了解详情,请参阅 Protobuf 指南。
PHP 解释器的运行模式
PHP 是一种用途广泛的脚本语言,根据使用情况,它有多种运行模式。PHP CGI(通用网关接口)具有显著优势,因为它可以在执行之间共享资源。
PHP 版本
建议您定期升级到较新的 PHP 版本,因为新版本通常具有更好的整体性能。支持的 PHP 版本列表。
未使用的 Google Ads API 版本
客户端库的所有版本均支持多个 Google Ads API 版本。 对于客户端库支持的每个版本的 Google Ads API,都有针对该版本的专用软件包。
可以安全地从客户端库中移除专用于未使用的 Google Ads API 版本的软件包。由于这有助于加快执行速度或减少内存占用空间,因此客户端库提供了以程序化方式执行此操作的实用程序。
示例
假设您要实现仅使用最新 API 版本 v20
的客户端库,并希望移除对未使用 API 版本 v19
和 v18
的支持。
在项目的 composer.json
文件中,定义一个 Composer 脚本(名为 remove-google-ads-api-version-support
),该脚本利用客户端库在 ApiVersionSupport
类中提供的实用程序:
"scripts": {
"remove-google-ads-api-version-support": [
"Google\\Ads\\GoogleAds\\Util\\ApiVersionSupport::remove"
]
}
然后,使用 Composer 脚本,将版本号作为参数,并打印一些状态消息:
# 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 v18 and v19 of the Google Ads API.
echo "# Removing support..."
composer run-script remove-google-ads-api-version-support -- 18 19
# 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
以下示例执行输出表明文件大小减少了 50M,并且仅剩余受支持的版本 V20
:
# Supported Google Ads API versions:
V18
V19
V20
# Vendor folder size:
110M ./vendor
# Removing support...
> Google\Ads\GoogleAds\Util\ApiVersionSupport::remove
Removing support for the version 18 of Google Ads API...
Done
Removing support for the version 19 of Google Ads API...
Done
# Supported Google Ads API versions:
V20
# Vendor folder size:
60M ./vendor
开发与生产
PHP 是一种解释型语言,它会先编译指令,然后再执行指令。这通常是有利的,因为在开发期间,来源经常会发生变化,而执行时间并不那么重要。不过,在生产时,情况恰恰相反,稳定性和性能成为主要考虑因素。
缓存
缓存是一种常见且强烈推荐的做法,因为它可以存储预编译的脚本指令,从而提高性能和稳定性。
OPcache 是最常用的解决方案,默认情况下可用。
自动充值
自动加载很常见,因为它可以通过加载有关类的预编译信息来提高性能和稳定性。
PHP 客户端库遵循 PSR-4 进行自动加载,并提供定义作为 composer.json
文件的一部分。然后,您可以直接使用 Composer 的专用选项,例如 --optimize-autoloader
或 --classmap-authoritative
。
日志记录
将记录器设置为 ERROR
等较高级别有助于减少执行时间开销和内存消耗。
如需了解详情,请参阅日志记录指南。
调试和性能分析
我们建议停用调试器和分析器工具,因为它们通常会带来一些执行时间开销。
预加载
自 PHP 7.4 起,OPcache 预加载可用于在内存中预加载脚本,比常规缓存更进一步。
必须设计脚本才能利用此功能,但 PHP 客户端库无法利用此功能,因为没有通用的 OPcache 预加载实现方法,并且内存使用量与性能提升之间的权衡高度依赖于特定项目和执行。