Google App Engine 标准 - composer update --lock |允许的内存大小耗尽 |错误 255

Google App Engine standard - composer update --lock | Allowed memory size exhausted | Error 255

我们有一个 PHP - Symfony 项目,我们希望在 Google Cloud App Engine Standard 上 运行 但我们无法使用 gcloud app deploy app.yml 部署该应用程序,因为构建失败。

app.yml

runtime: php
service: "papi-dev"
instance_class: F2
env_variables:
  APP_ENV: prod
  APP_DEBUG: true
  DATABASE_URL: mysql://p...
runtime_config:
  document_root: ./public
  front_controller_file: index.php
  enable_stackdriver_integration: true
handlers:
# Declare the build and bundles directory as static assets to be served by the
# App Engine CDN.
- url: /build
  static_dir: public/build

composer.json

{
    "type": "project",
    "license": "proprietary",
    "require": {
        "php": "7.2.*",
        "ext-ctype": "*",
        "ext-iconv": "*",
        "ext-json": "*",
        "api-platform/api-pack": "^1.1",
        "doctrine/doctrine-fixtures-bundle": "^3.0",
        "friendsofsymfony/elastica-bundle": "^5.0",
        "friendsofsymfony/oauth-server-bundle": "^1.6",
        "friendsofsymfony/user-bundle": "^2.1",
        "google/apiclient": "^2.0",
        "google/cloud-error-reporting": "^0.12.1",
        "google/cloud-logging": "^1.14",
        "guzzlehttp/guzzle": "~6.0",
        "jms/serializer-bundle": "^2.4",
        "lexik/jwt-authentication-bundle": "^2.5",
        "nelmio/cors-bundle": "^1.5",
        "pear/net_dns2": "^1.4",
        "productsupcom/jenkins-php-api": "^0.1.4",
        "sendgrid/sendgrid": "^7.2",
        "sensio/framework-extra-bundle": "^5.2",
        "symfony/console": "*",
        "symfony/dotenv": "*",
        "symfony/expression-language": "*",
        "symfony/flex": "^1.1",
        "symfony/framework-bundle": "*",
        "symfony/lock": "4.1.*",
        "symfony/maker-bundle": "^1.7",
        "symfony/monolog-bundle": "^3.3",
        "symfony/orm-pack": "^1.0",
        "symfony/proxy-manager-bridge": "*",
        "symfony/templating": "4.1.*",
        "symfony/translation": "4.2.*",
        "symfony/yaml": "*",
        "webonyx/graphql-php": "^0.12.6",
        "wisembly/elephant.io": "^3.3"
    },
    "require-dev": {
        "symfony/phpunit-bridge": "4.1.*"
    },
    "config": {
        "preferred-install": {
            "*": "dist"
        },
        "sort-packages": true
    },
    "autoload": {
        "psr-4": {
            "App\": "src/"
        }
    },
    "autoload-dev": {
        "psr-4": {
            "App\Tests\": "tests/"
        }
    },
    "replace": {
        "paragonie/random_compat": "2.*",
        "symfony/polyfill-ctype": "*",
        "symfony/polyfill-iconv": "*",
        "symfony/polyfill-php71": "*",
        "symfony/polyfill-php70": "*",
        "symfony/polyfill-php56": "*"
    },
    "scripts": {
        "auto-scripts": {
            "cache:clear": "symfony-cmd",
            "assets:install %PUBLIC_DIR%": "symfony-cmd"
        },
        "post-install-cmd": [
            "@auto-scripts"
        ],
        "post-update-cmd": [
            "@auto-scripts"
        ]
    },
    "conflict": {
        "symfony/symfony": "*"
    },
    "extra": {
        "symfony": {
            "allow-contrib": false,
            "require": "4.2.*"
        }
    }
}

生成器日志

Step #1 - "builder": INFO composer_update_lock composer update --lock
Step #1 - "builder": INFO `composer_update_lock` stdout:
Step #1 - "builder": 
Step #1 - "builder": Fatal error: Allowed memory size of 1610612736 bytes exhausted (tried to allocate 9437184 bytes) in phar:///usr/local/bin/composer/src/Composer/Repository/ComposerRepository.php on line 565
Step #1 - "builder": 
Step #1 - "builder": Check https://getcomposer.org/doc/articles/troubleshooting.md#memory-limit-errors for more info on how to handle out of memory errors.
Step #1 - "builder": INFO `composer_update_lock` had stderr output:
Step #1 - "builder": Do not run Composer as root/super user! See https://getcomposer.org/root for details
Step #1 - "builder": Loading composer repositories with package information
Step #1 - "builder": Updating dependencies (including require-dev)
Step #1 - "builder": Package operations: 128 installs, 0 updates, 0 removals
Step #1 - "builder": - Installing symfony/flex (v1.1.8): Downloading (connecting...)Downloading (0%) Downloading (20%)Downloading (25%)Downloading (45%)Downloading (60%)Downloading (65%)Downloading (75%)Downloading (80%)Downloading (90%)Downloading (95%)Downloading (100%)
Step #1 - "builder": 
Step #1 - "builder": ERROR error: `composer_update_lock` returned code: 255

在我们向 composer.json 添加更多包之前,部署命令一直有效。到目前为止,我的最佳猜测是构建停止工作,因为 github 提交到 cloud builder image,它在每次 deploy/build 执行时执行 composer update --lock

由 Google 解决 - 调用 composer install 而不是 composer update。