Mettre à niveau la version de Commerce

Vous pouvez mettre à niveau la base de code Adobe Commerce vers une version plus récente. Avant de mettre à niveau votre projet, consultez la section Configuration requise du guide Installation pour connaître la configuration requise pour la dernière version du logiciel.

Selon la configuration de votre projet, vos tâches de mise à niveau peuvent inclure les éléments suivants :

  • Mettez à jour les services tels que MariaDB (MySQL), OpenSearch, RabbitMQ et Redis pour des raisons de compatibilité avec les nouvelles versions d’Adobe Commerce.
  • Convertissez un fichier de gestion de configuration plus ancien.
  • Mettez à jour le fichier .magento.app.yaml avec de nouveaux paramètres pour les hooks et les variables d’environnement.
  • Mettez à niveau les extensions tierces vers la dernière version prise en charge.
  • Mettez à jour le fichier .gitignore.
TIP
Avant de commencer une mise à niveau ou un processus d’application de correctifs, créez une branche active à partir de l’environnement d’intégration et extrayez la nouvelle branche sur votre station de travail locale. Dédier une branche à la mise à niveau ou au processus de correctif permet d’éviter toute interférence avec votre travail en cours.
TIP
Pour les projets Pro, vous devez envoyer un ticket d’assistance Adobe Commerce pour installer ou mettre à jour les services dans les environnements Staging et Production uniquement.
Indiquez les changements de service nécessaires, incluez vos fichiers .magento.app.yaml et services.yaml mis à jour, et indiquez la version PHP dans le ticket. Pour les modifications en libre-service de la version PHP, des extensions ou des paramètres d'environnement, voir paramètres PHP dans Configuration de l'application.
Pour apporter des modifications à un environnement de production en ligne (Pro uniquement), un préavis d’au moins 48 heures est requis. L’équipe en charge de l’infrastructure cloud dispose ainsi de suffisamment de temps pour rassembler les ressources et effectuer une mise à niveau sécurisée. La période de préavis commence lorsque l’équipe d’infrastructure accuse réception de la demande et planifie la mise à niveau, à l’exclusion des week-ends. Par exemple, pour que les mises à niveau de service soient terminées un lundi, un accusé de réception de la mise à niveau prévue doit être reçu avant le mercredi. Pendant les périodes de pointe, le traitement de votre demande peut prendre plus de temps.

Mise à niveau à partir de versions plus anciennes

Si vous commencez une mise à niveau à partir d'une version de Commerce antérieure à la version 2.1, certaines restrictions de la base de code Adobe Commerce peuvent affecter votre capacité à mettre à jour vers une version spécifique de ECE-Tools ou à mettre à niveau vers la prochaine version de Commerce prise en charge. Utilisez le tableau suivant pour déterminer le meilleur chemin d’accès :

Version actuelle
Chemin de mise à niveau
2.1.3 et versions antérieures
Mettez à niveau Adobe Commerce vers la version 2.1.4 ou une version ultérieure avant de continuer. Effectuez ensuite une mise à niveau ponctuelle pour installer ECE-Tools.
2.1.4 - 2.1.14
Mise à jour du package ECE-Tools.
Voir les notes de mise à jour de la version 2002.0.9 et des versions ultérieures 2002.0.x.
2.1.15 - 2.1.16
Mise à jour du package ECE-Tools.
Voir les notes de mise à jour de la version 20020.9 et des versions ultérieures.
2.2.x et versions ultérieures
Mise à jour du package ECE-Tools.
Voir les notes de mise à jour de la version 20020.8 et des versions ultérieures.
NOTE
Si vous utilisez une version d’Adobe Commerce sur une infrastructure cloud qui ne contient pas le package ece-tools, vous devez effectuer une mise à niveau ponctuelle sur votre projet cloud pour supprimer les packages obsolètes. Si vous utilisez actuellement le module ece-tools et que vous devez le mettre à jour, voir Mettre à jour le module ECE-Tools.

Gestion de la configuration

Les versions plus anciennes d’Adobe Commerce, telles que 2.1.4 ou les versions ultérieures à 2.2.x ou les versions ultérieures, utilisaient un fichier config.local.php pour la gestion de la configuration. Les versions 2.2.0 et ultérieures d’Adobe Commerce utilisent le fichier config.php, qui fonctionne exactement comme le fichier config.local.php, mais il comporte différents paramètres de configuration qui incluent une liste de vos modules activés et des options de configuration supplémentaires.

Lors de la mise à niveau à partir d’une version plus ancienne, vous devez migrer le fichier config.local.php pour utiliser le fichier config.php plus récent. Pour sauvegarder votre fichier de configuration et en créer un, procédez comme suit.

Pour créer un fichier config.php temporaire :

  1. Créez une copie config.local.php fichier et nommez-le config.php.

  2. Ajoutez ce fichier au dossier app/etc de votre projet.

  3. Ajoutez et validez le fichier dans votre branche.

  4. Envoyez le fichier à votre branche d’intégration.

  5. Poursuivez le processus de mise à niveau.

WARNING
Après la mise à niveau, vous pouvez supprimer le fichier config.php et générer un nouveau fichier complet. Vous ne pouvez supprimer ce fichier que pour le remplacer cette fois-ci. Après avoir généré un nouveau fichier config.php complet, vous ne pouvez pas supprimer le fichier pour en générer un nouveau. Voir Gestion de la configuration et déploiement du pipeline.

Vérifier les dépendances du compositeur de structure d'envoi

Lors de la mise à niveau vers 2.3.x ou une version ultérieure à partir de 2.2.x, vérifiez que les dépendances de Zend Framework ont été ajoutées à la propriété autoload du fichier composer.json pour prendre en charge Laminas. Ce plug-in prend en charge les nouvelles exigences de la structure Zend, qui a migré vers le projet Laminas. Voir Migration de Zend Framework vers le projet Laminas sur le DevBlog Magento.

Pour vérifier la configuration auto-load:psr-4, procédez comme suit

  1. Sur votre station de travail locale, accédez au répertoire du projet.

  2. Consultez votre branche d’intégration.

  3. Ouvrez le fichier composer.json dans un éditeur de texte.

  4. Consultez la section autoload:psr-4 pour la mise en œuvre du gestionnaire de plug-ins Zend pour la dépendance des contrôleurs.

    code language-json
     "autoload": {
        "psr-4": {
           "Magento\\Framework\\": "lib/internal/Magento/Framework/",
           "Magento\\Setup\\": "setup/src/Magento/Setup/",
           "Magento\\": "app/code/Magento/",
           "Zend\\Mvc\\Controller\\": "setup/src/Zend/Mvc/Controller/"
        },
    }
    
  5. Si la dépendance Zend est manquante, mettez à jour le fichier composer.json :

    • Ajoutez la ligne suivante à la section autoload:psr-4 .

      code language-json
      "Zend\\Mvc\\Controller\\": "setup/src/Zend/Mvc/Controller/"
      
    • Mettez à jour les dépendances du projet.

      code language-bash
      composer update
      
    • Ajout, validation et modifications de code push.

      code language-bash
      git add -A
      
      code language-bash
      git commit -m "Add Zend plugin manager implementation for controllers dependency for Laminas support"
      
      code language-bash
      git push origin <branch-name>
      
    • Fusionnez les modifications apportées à l’environnement d’évaluation, puis à la production.

Fichiers de configuration

Avant de mettre à niveau l’application, vous devez mettre à jour les fichiers de configuration de votre projet afin de tenir compte des modifications apportées aux paramètres de configuration par défaut d’Adobe Commerce sur l’infrastructure cloud ou l’application. Les dernières valeurs par défaut se trouvent dans le référentiel GitHub magento-cloud.

.magento.app.yaml

Vérifiez toujours les valeurs contenues dans le fichier .magento.app.yaml pour la version installée, car il contrôle la manière dont votre application crée et déploie l’infrastructure cloud. L’exemple suivant concerne la version 2.4.7 et utilise le compositeur 2.7.2. La propriété build: flavor: n’est pas utilisée pour le compositeur 2.x. Voir Installation et utilisation du compositeur 2.

Pour mettre à jour le fichier .magento.app.yaml :

  1. Sur votre station de travail locale, accédez au répertoire du projet.

  2. Ouvrez et modifiez le fichier magento.app.yaml.

  3. Mettez à jour les options PHP.

    code language-yaml
    type: php:8.3
    
    build:
        flavor: none
    dependencies:
        php:
            composer/composer: '2.7.2'
    
  4. Modifiez les build de propriété hooks et les commandes deploy.

    code language-yaml
    hooks:
        # We run build hooks before your application has been packaged.
        build: |
            set -e
            composer install
            php ./vendor/bin/ece-tools run scenario/build/generate.xml
            php ./vendor/bin/ece-tools run scenario/build/transfer.xml
        # We run deploy hook after your application has been deployed and started.
        deploy: |
            php ./vendor/bin/ece-tools run scenario/deploy.xml
        # We run post deploy hook to clean and warm the cache. Available with ECE-Tools 2002.0.10.
        post_deploy: |
            php ./vendor/bin/ece-tools run scenario/post-deploy.xml
    
  5. Ajoutez les variables d’environnement suivantes à la fin du fichier .

    Pour Adobe Commerce 2.2.x à 2.3.x-

    code language-yaml
    variables:
        env:
            CONFIG__DEFAULT__PAYPAL_ONBOARDING__MIDDLEMAN_DOMAIN: 'payment-broker.magento.com'
            CONFIG__STORES__DEFAULT__PAYMENT__BRAINTREE__CHANNEL: 'Magento_Enterprise_Cloud_BT'
            CONFIG__STORES__DEFAULT__PAYPAL__NOTATION_CODE: 'Magento_Enterprise_Cloud'
    

    Pour Adobe Commerce 2.4.x-

    code language-yaml
    variables:
        env:
            CONFIG__DEFAULT__PAYPAL_ONBOARDING__MIDDLEMAN_DOMAIN: 'payment-broker.magento.com'
            CONFIG__STORES__DEFAULT__PAYPAL__NOTATION_CODE: 'Magento_Enterprise_Cloud'
    
  6. Enregistrez le fichier. Ne validez pas et n’envoyez pas encore les modifications à l’environnement distant.

  7. Poursuivez le processus de mise à niveau.

composer.json

Avant la mise à niveau, vérifiez toujours que les dépendances du fichier composer.json sont compatibles avec la version Adobe Commerce.

Pour mettre à jour le fichier composer.json pour Adobe Commerce version 2.4.4 et ultérieure :

  1. Ajoutez les allow-plugins suivantes à la section config :

    code language-json
    "config": {
       "allow-plugins": {
          "dealerdirect/phpcodesniffer-composer-installer": true,
          "laminas/laminas-dependency-plugin": true,
          "magento/*": true
       }
    },
    
  2. Ajoutez le module externe suivant à la section require :

    code language-json
    "require": {
        "magento/composer-root-update-plugin": "^2.0.3"
    },
    
  3. Ajoutez le composant suivant à la section extra:component_paths :

    code language-json
    "extra": {
       "component_paths": {
          "tinymce/tinymce": "lib/web/tiny_mce_5"
       },
    },
    
  4. Enregistrez le fichier. Ne validez pas et n’envoyez pas encore de modifications à votre branche.

  5. Poursuivez le processus de mise à niveau.

Sauvegarde du projet

Nous vous recommandons de créer une sauvegarde de votre projet avant une mise à niveau. Suivez les étapes ci-après pour sauvegarder vos environnements d’intégration, d’évaluation et de production.

Pour sauvegarder la base de données et le code de votre environnement d’intégration :

  1. Créez une sauvegarde locale de la base distante.

    code language-bash
    magento-cloud db:dump
    
    note note
    NOTE
    La commande magento-cloud db:dump exécute la commande mysqldump avec l'indicateur --single-transaction, qui vous permet de sauvegarder votre base de données sans verrouiller les tables.
  2. Sauvegardez le code et le média.

    code language-bash
    php bin/magento setup:backup --code [--media]
    

    Vous pouvez éventuellement omettre [--media] si vous disposez d’un grand nombre de fichiers statiques qui se trouvent déjà dans le contrôle de code source.

Pour sauvegarder la base de données de votre environnement d’évaluation ou de production avant le déploiement :

  1. Utilisez SSH pour vous connecter à l’environnement distant.

  2. Créez une image mémoire de la base de données. Pour choisir un répertoire cible pour l’image mémoire de la base de données, utilisez l’option --dump-directory.

    code language-bash
    vendor/bin/ece-tools db-dump
    

    L’opération de vidage crée un fichier d’archive dump-<timestamp>.sql.gz dans votre répertoire de projet distant. Voir Sauvegarde de la base de données.

Mise à niveau de l’application

Consultez les informations versions de service pour connaître les dernières exigences en matière de version logicielle avant de mettre à niveau votre application.

Pour mettre à niveau la version de l’application :

  1. Sur votre station de travail locale, accédez au répertoire du projet.

  2. Définissez la version de mise à niveau à l’aide de la syntaxe de contrainte de version.

    code language-bash
    composer require "magento/magento-cloud-metapackage":">=CURRENT_VERSION <NEXT_VERSION" --no-update
    
    note note
    NOTE
    Vous devez utiliser la syntaxe de contrainte de version pour mettre à jour le package ece-tools. La contrainte de version se trouve dans le fichier composer.json correspondant à la version du modèle d'application modèle d'application que vous utilisez pour la mise à niveau.
  3. Mettez à jour le projet.

    code language-bash
    composer update
    
  4. Examinez les correctifs actuellement appliqués :

    • Si des correctifs sont installés dans le répertoire m2-hotfixes, envoyez un ticket d’assistance Adobe Commerce et contactez l’assistance Adobe Commerce pour vérifier quels correctifs peuvent toujours être appliqués à la nouvelle version. Supprimez le ou les correctifs non applicables du répertoire m2-hotfixes.

    • Si des [correctifs de qualité] sont appliqués dans le fichier .magento.env.yaml, vérifiez s’ils peuvent toujours être appliqués à la nouvelle version. Supprimez le ou les correctifs non applicables de la section QUALITY_PATCHES du fichier .magento.env.yaml.

    Méthode 1 : vérifiez les versions applicables dans les notes de mise à jour des correctifs de qualité

    Méthode 2 : affichage des correctifs et de l’état disponibles

    Méthode 3 : Rechercher des correctifs

  5. Ajout, validation et modifications de code push.

    code language-bash
    git add -A
    
    code language-bash
    git commit -m "Upgrade"
    
    code language-bash
    git push origin <branch-name>
    

    git add -A est nécessaire pour ajouter tous les fichiers modifiés au contrôle de code source en raison de la manière dont le compositeur marshale les packages de base. composer install et composer update marshalent les fichiers du package de base (magento/magento2-base et magento/magento2-ee-base) dans la racine du package.

    Les fichiers que le compositeur marshale appartiennent à la nouvelle version d’Adobe Commerce, afin de remplacer la version obsolète de ces mêmes fichiers. Actuellement, le marshalling est désactivé dans Adobe Commerce, vous devez donc ajouter les fichiers marshalés au contrôle de code source.

  6. Attendez la fin du déploiement.

  7. Vérifiez la mise à niveau dans votre environnement d’intégration, d’évaluation ou de production à l’aide de SSH pour vous connecter et vérifier la version.

    code language-bash
    php bin/magento --version
    

Créer un fichier config.php

Comme indiqué dans Gestion de la configuration, après la mise à niveau, vous devez créer un fichier config.php mis à jour. Effectuez toutes les modifications de configuration supplémentaires via l’Administration dans votre environnement d’intégration.

Pour créer un fichier de configuration spécifique au système :

  1. À partir du terminal, utilisez une commande SSH pour générer le fichier /app/etc/config.php pour l’environnement.

    code language-bash
    ssh <SSH-URL> "<Command>"
    

    Par exemple, pour Pro, pour exécuter le scd-dump sur la branche integration :

    code language-bash
    ssh <project-id-integration>@ssh.us.magentosite.cloud "php vendor/bin/ece-tools config:dump"
    
  2. Transférez le fichier config.php vers vos stations de travail locales à l'aide de rsync ou scp. Vous pouvez uniquement ajouter ce fichier à la branche localement.

    code language-bash
    rsync <SSH-URL>:app/etc/config.php ./app/etc/config.php
    
  3. Ajout, validation et modifications de code push.

    code language-bash
    git add app/etc/config.php && git commit -m "Add system-specific configuration" && git push origin master
    

    Cela génère un fichier /app/etc/config.php mis à jour avec une liste de modules et des paramètres de configuration.

WARNING
Pour une mise à niveau, supprimez le fichier config.php. Une fois ce fichier ajouté à votre code, vous ne devez pas le supprimer. Si vous devez supprimer ou modifier des paramètres, modifiez le fichier manuellement.

Mettre à niveau les extensions

Passez en revue vos pages d’extension et de module tiers sur Marketplace ou d’autres sites d’entreprise et vérifiez la prise en charge d’Adobe Commerce et d’Adobe Commerce sur l’infrastructure cloud. Si vous devez mettre à niveau des extensions et modules tiers, Adobe recommande de travailler dans une nouvelle branche d’intégration avec vos extensions désactivées.

Pour vérifier et mettre à niveau vos extensions :

  1. Créez une branche sur votre station de travail locale.

  2. Désactivez vos extensions selon vos besoins.

  3. Lorsqu’elles sont disponibles, téléchargez les mises à niveau d’extension.

  4. Installez la mise à niveau comme indiqué dans la documentation tierce.

  5. Activez et testez l’extension.

  6. Ajoutez, validez et envoyez les modifications de code à la télécommande.

  7. Envoyez et testez dans votre environnement d’intégration.

  8. Push vers l’environnement d’évaluation pour effectuer des tests dans un environnement de pré-production.

Adobe recommande vivement de mettre à niveau votre environnement de production avant y compris les extensions mises à niveau dans le processus de lancement de votre site.

NOTE
Lorsque vous mettez à niveau votre version de l’application, le processus de mise à niveau se met automatiquement à jour vers la dernière version du module Fastly CDN.

Résolution des problèmes de mise à niveau

Si la mise à niveau a échoué, vous recevez un message d’erreur dans le navigateur indiquant que vous ne pouvez pas accéder à votre storefront ou au panneau d’administration :

There has been an error processing your request
Exception printing is disabled by default for security reasons.
  Error log record number: <error-number>

Pour résoudre l’erreur :

  1. Sur votre station de travail locale, accédez au répertoire du projet.

  2. Utilisez SSH pour vous connecter à l’environnement distant.

    code language-bash
    magento-cloud ssh
    
  3. Ouvrez le fichier ./app/var/report/<error number>.

  4. Examinez les journaux et déterminez la source du problème.

  5. Ajout, validation et modifications de code push.

    code language-bash
    git add -A && git commit -m "Fixed deployment failure" && git push origin <branch-name>
    
recommendation-more-help