Convertir un portail TAR en portail RPM

Edge pour Private Cloud v4.18.05

La version 4.18.05 du portail Apigee Developer Services (ou simplement le portail) ne vous permet pas de mettre à jour une version précédente du portail basée sur tar. Vous ne pouvez mettre à jour directement une version du portail basée sur RPM vers la version 4.18.05.

Toutefois, vous pouvez convertir une version tar du portail en instance basée sur RPM 4.18.05 du portail. Dans le cadre de ce processus, vous migrez le MySQL/MariaDB du portail existant vers une base de données Postgres. Une fois la conversion effectuée, votre portail reste un portail basé sur RPM.

Vous pouvez migrer de nombreuses versions précédentes du portail basé sur tar vers un portail basé sur RPM, y compris les versions 4.16.09 et 4.17.01, et pas seulement la version 4.17.05. La seule exigence est que le portail exécute Drupal 7 ou une version ultérieure. Pour vérifier votre version de Drupal, sélectionnez Rapports > Rapports d'état dans le menu Drupal. La version de Drupal s'affiche sur la première ligne de la sortie.

Voici les étapes générales à suivre pour migrer d'un portail basé sur tar vers un portail basé sur RPM:

  • Installez la version 4.18.05 basée sur RPM du portail sur un nouveau nœud.
  • Créez une base de données Postgres sur le portail basé sur RPM.
  • Migrez la base de données du portail à partir du portail basé sur tar.
  • Copiez tous les fichiers accessoires du portail tar vers le portail RPM.
  • Mettez à jour les entrées DNS pour qu'elles pointent vers le nouveau portail basé sur RPM.

    Notez que la version du portail basée sur RPM utilise le port 8079 par défaut, tandis que la version basée sur tar utilise le port 80. Assurez-vous d'utiliser le bon numéro de port dans votre entrée DNS. Pour en savoir plus sur l'utilisation d'un autre port, consultez la section Définir le port HTTP utilisé par le portail.

Nouveau répertoire d'installation par défaut après la conversion

Après avoir mis à jour une installation qui utilise désormais Nginx/Postgres, le répertoire racine a changé comme suit:

/opt/apigee/apigee-drupal

par :

/opt/apigee/apigee-drupal/wwwroot

Procédure de conversion du portail

Pour convertir le portail en installation basée sur RPM:

  1. Installez la version 4.18.05 du portail basée sur RPM sur un nœud différent de celui de votre portail basé sur tar.
  2. Sur le portail basé sur RPM, créez une base de données Postgres. Vous migrez ensuite la base de données du portail basé sur tar vers cette nouvelle base de données :
    1. Connectez-vous à psql :
      psql -h localhost -p 5432 -U apigee

      Saisissez votre mot de passe Postgres tel que défini par la propriété PG_PWD dans le fichier de configuration du portail.

    2. Créez une base de données Postgred :
      CREATE DATABASE newportaldb;
    3. Quittez psql :
      \q
  3. Sur le portail basé sur tar, supprimez les anciens modules qui ne sont plus utilisés :

    cd /var/www/html
    drush sql-query --db-prefix "DELETE from {system} where name = 'apigee_account' AND type = 'module';"
    drush sql-query --db-prefix "DELETE from {system} where name = 'apigee_checklist' AND type = 'module';"
    drush sql-query --db-prefix "DELETE from {system} where name = 'apigee_sso_ui' AND type = 'module';"

  4. Sur le portail basé sur tar, installez et configurez le module Drupal du migrateur :
    1. cd /tmp 
    2. wget https://ftp.drupal.org/files/projects/dbtng_migrator-7.x-1.4.tar.gz 
    3. gunzip /tmp/dbtng_migrator-7.x-1.4.tar.gz 
    4. tar -xvf /tmp/dbtng_migrator-7.x-1.4.tar --directory /var/www/html/sites/all/modules 
    5. Connectez-vous au portail en tant qu'administrateur.
    6. Sélectionnez Modules dans le menu Drupal.
    7. Activez le module DBTNG Migrator.
    8. Enregistrez la configuration.
  5. Sur le portail basé sur tar, modifiez /var/www/html/sites/default/settings.php pour ajouter une deuxième configuration de base de données pointant vers la base de données nouvellement créée sur le portail basé sur RPM. La configuration de la base de données actuelle est nommée "default". Nommez votre nouvelle configuration "custom", comme illustré dans l'exemple suivant :
    $databases = array (
      'default' =>
      array (
        'default' =>
        array (
          'database' => 'devportal',
          'username' => 'devportal',
          'password' => 'devportal',
          'host' => 'localhost',
          'port' => '',
          'driver' => 'mysql',
          'prefix' => '',
        ),
      ),
      'custom' =>
      array (
        'default' =>
        array (
          'database' => 'newportaldb',
          'username' => 'apigee',
          'password' => 'postgres',
          'host' => '192.168.168.100',
          'port' => '5432',
          'driver' => 'pgsql',
          'prefix' => '',
        )
      )
    );

    host et port spécifient l'adresse IP et le port du serveur Postgres. Postgres utilise le port 5432 pour les connexions.

  6. Sur le portail basé sur tar, installez le pilote Postgres :
    1. Utilisez Yum pour installer le pilote :
      yum install php-pdo_pgsql
    2. Modifiez /etc/php.ini pour ajouter la ligne suivante n'importe où dans le fichier :
      extension=pgsql.so
    3. Redémarrez Apache :
      service httpd restart
  7. Sur le portail basé sur tar, migrez la base de données du portail vers le portail basé sur RPM :
    1. Connectez-vous au portail en tant qu'administrateur.
    2. Sélectionnez Structure > Migrateur dans le menu Drupal.
    3. Choisissez votre base de données d'origine sur le portail basé sur tar, default, et la base de données de destination, custom, en fonction du fichier settings.php indiqué ci-dessus.
    4. Cliquez sur Transférer. La base de données basée sur tar est migrée vers la base de données basée sur RPM.
  8. Copiez le répertoire sites du serveur basé sur tar vers le serveur basé sur RPM. Les chemins indiqués dans les étapes suivantes sont basés sur des chemins par défaut. Modifiez-les si nécessaire pour votre installation.
    1. Sur le portail basé sur tar, regroupez le répertoire /var/www/html/sites :
      cd /var/www/html/sites
      tar -cvzf /tmp/sites.tar.gz .
    2. Copiez /tmp/sites.tar.gz dans /opt/apigee/apigee-drupal/wwwroot/sites sur le serveur basé sur RPM.
    3. Dégroupez le répertoire des sites, mais ne remplacez pas les fichiers importants.
      1. Sauvegardez le fichier settings.php :
        sudo cp /opt/apigee/apigee-drupal/wwwroot/sites/default/settings.php
          /opt/apigee/apigee-drupal/wwwroot/sites/default/settings.bak.php
      2. Sauvegardez le répertoire files existant :
        sudo mv /opt/apigee/apigee-drupal/wwwroot/sites/default/files
          /opt/apigee/apigee-drupal/wwwroot/sites/default/files_old
      3. Sauvegardez le répertoire sites existant :
        tar -cvzf /tmp/sites_old.tar.gz /opt/apigee/apigee-drupal/wwwroot/sites
      4. Décompressez et décompressez le répertoire sites à partir du serveur basé sur tar :
        gunzip /opt/apigee/apigee-drupal/wwwroot/sites/sites.tar.gz
        tar -xvf /opt/apigee/apigee-drupal/wwwroot/sites/sites.tar
      5. Assurez-vous que les fichiers copiés sont correctement attribués :
        chown -R apigee:apigee /opt/apigee/apigee-drupal/wwwroot/sites/
      6. Restaurez le fichier settings.php :
        sudo cp /opt/apigee/apigee-drupal/wwwroot/sites/default/settings.bak.php
          /opt/apigee/apigee-drupal/wwwroot/sites/default/settings.php
      7. Déplacer des fichiers privés vers un nouvel emplacement :
        cp -r /opt/apigee/apigee-drupal/wwwroot/sites/default/files/private/* /opt/apigee/data/apigee-drupal-devportal/private
        rm -rf /opt/apigee/apigee-drupal/wwwroot/sites/default/files/private
        chown -R apigee:apigee /opt/apigee/data/apigee-sap-drupal-devportal/private
  9. Sur le portail basé sur tar, uniquement si vous avez modifié le chemin d'accès au répertoire racine Web sur le portail basé sur tar à partir du chemin d'accès par défaut de /var/www/html: exécutez drush status et examinez le chemin d'accès files et le chemin d'accès private files :
    cd /var/www/html
    drush status

    Si les fichiers/fichiers privés ne se trouvent pas dans le répertoire sites, copiez-les sur le serveur basé sur RPM, comme indiqué ci-dessus.

  10. Sur le portail basé sur RPM, mettez à jour /opt/apigee/apigee-drupal/wwwroot/sites/default/settings.php pour définir les propriétés de la base de données par défaut :
    vi /opt/apigee/apigee-drupal/wwwroot/sites/default/settings.php

    Définissez la description de la base de données par défaut dans settings.php :

    $databases = array (
      'default' =>
      array (
        'default' =>
        array (
          'database' => 'newportaldb',
          'username' => 'apigee',
          'password' => 'postgres',
          'host' => 'localhost', 'port' => '5432',
          'driver' => 'pgsql',
          'prefix' => '',
        )
      )
    );

    database spécifie la nouvelle base de données que vous avez créée, username et password sont définis pour la base de données personnalisée sur le portail basé sur tar, et prefix est vide.

  11. Sur le portail basé sur RPM, la version basée sur RPM du portail contient moins de modules Drupal que la version basée sur tar. Après avoir migré vers le portail basé sur RPM, vous devez rechercher les modules manquants et les installer si nécessaire.
    1. Installez le missing_module Drupal utilisé pour détecter les modules manquants :
      cd /opt/apigee/apigee-drupal/wwwroot
      drush dl missing_module
      drush en missing_module
    2. Connectez-vous au portail basé sur RPM en tant qu'administrateur.
    3. Sélectionnez Rapports > Rapports d'état dans le menu Drupal et recherchez les modules manquants.
    4. Utilisez ce rapport pour installer les modules manquants ou exécutez les commandes suivantes :
      cd /opt/apigee/apigee-drupal/wwwroot
      drush dl <moduleA> <moduleB> ...
      drush en <moduleA> <moduleB> ...
    5. Une fois tous les modules activés, assurez-vous que les fichiers appartiennent à l'utilisateur apigee :
      chown -LR apigee:apigee /opt/apigee/apigee-drupal/wwwroot

      Pour en savoir plus sur les autorisations de fichiers, consultez la page https://www.drupal.org/node/244924.

  12. Sur le portail basé sur RPM, exécutez update.php dans un navigateur pour supprimer les erreurs liées aux modules manquants :
    1. Connectez-vous au portail basé sur RPM en tant qu'administrateur.
    2. Dans le navigateur, accédez à l'URL suivante :
      http://portal_IP_or_DNS:8079/update.php

      portal_IP_or_DNS est l'adresse IP ou le nom de domaine du portail basé sur RPM.

    3. Suivez les instructions à l'écran.
  13. Mettez à jour les entrées DNS pour qu'elles pointent vers votre nouveau portail basé sur RPM.

    Notez que la version du portail basée sur RPM utilise le port 8079 par défaut, tandis que la version basée sur tar utilise le port 80. Assurez-vous d'utiliser le bon numéro de port dans votre entrée DNS. Pour savoir comment utiliser un autre port, consultez la section Définir le port HTTP utilisé par le portail.

La conversion est terminée.