Installation d’Akeneo PIM 7.0 – OVH Kimsufi – Debian 10 – myVesta

Publié par David le

Ce tutoriel est plus au moins une traduction de la documentation officielle d’installation d’Akeneo PIM 7.0 avec quelques petits ajouts. J’ai choisi la méthode manuelle.

J’ai reçu beaucoup de messages me demandant ce que je pensais d’Akeneo PIM après deux ans d’utilisation. Pour moi, ce type de logiciel est indispensable si vous avez beaucoup de produit et beaucoup de canaux de ventes. Particulièrement si votre catalogue est complexe, avec beaucoup d’attributs de tout type (couleur, taille, id_prestashop, Amazon ASIN, EAN13, Images …). C’est dommage que Odoo n’intègre pas de PIM digne de ce nom, mais la particularité d’Akeneo PIM est la facilité de travailler avec les imports/exports CSV et XLSX et Excel. En combinant le PIM, Excel et les macros et un ERP comme Odoo, vous n’aurez plus aucun problème pour gérer l’écosystème de votre entreprise. Vous gagnerez beaucoup de temps pour remplir les bases de données de votre Prestashop, Magento, Amazon Seller ou même réaliser des catalogues classiques. Des connecteurs entre les différents outils existent. Je ne les ai pas testés, mais j’essayerai de le faire prochainement.

J’ai gardé les sources de Akeoneo PIM sur mon espace personnel. Vous pouvez les télécharger en cliquant sur ce lien.

Installation des prérequis

Prenez soin de vous logger avec l’utilisateur 1000 (ubuntu dans le cas d’un serveur OVH sous cette distribution).

Pour le cas de myVesta, veuillez créer un utilisateur pim7 et un domaine Web. Par exemple monpim7.com.

MySQL 8.0

Lors de l’installation de MySQL 8.0, vous devrez choisir la méthode d’authentification. Sélectionnez Use Legacy Authentication Method. L’autre méthode Strong Password Encryption n’est pas pris en charge par Akeneo PIM.

On vérifie l’état du système.

La sortie devrait ressembler à quelque chose comme ci-dessous, montrant que le service Odoo est actif et en cours d’exécution :

PHP 8.1

L’installation de PHP et de ses extensions.

Si vous avez myVesta, il suffit de l’installer sur le Panel de myVesta avec le script multi-php.

Composer v2

Installation par le script automatique

Les détails de cette installation peuvent être consultés sur la documentation de Composer.

Elasticsearch 8.4

On installe la clé PGP et les paquets par le dépôt officiel.

La documentation d’Akeneo PIM indique qu’il est fortement conseillé d’augmenter la variable du noyau Linux MAX_MAP_COUNT. Voici comment la mettre à jour. La première commande sera effective sur la session en cours et la seconde pour chaque redémarrage du serveur.

Les détails de cette installation peuvent être consultés sur la documentation de Elasticsearch.

Apache2

N’oubliez de désactiver php5 si vous importez une ancienne installation d’Apache avec mod_php :

Configuration du système

MySQL

On crée les base de données nécessaire au bon fonctionnement du PIM. On nommera la base de donnée, l’utilisateur et le mot de passe akeneo_pim.

Si vous avez myVesta, il suffit d’ajouter la base sur le Panel.

PHP

  • On configure le fichier de configuration php-cli

Et on modifie les valeurs :

Pour date.timezone, utilisez la bonne nomenclature disponible sur la documentation de PHP. Europe/Paris par exemple pour la France.

  • De même pour le fichier de configuration php-fpm

Et on modifie les valeurs :

Enfin, il faut configurer les utilisateurs php :

  • On récupère les identifiant de l’utilisateur actuel :

Dans cet exemple, les utilisateurs is my_user et le groupe est my_group.

  • On arrête php-fpm

  • On ouvre le fichier de la pool www de php-fpm

Et on modifie les valeurs :

  • On redémarre php-fpm

Dans le cas de myVesta, le fichier à modifier est /etc/php/8.1/fpm/pool.d/pim7.mcdtoolbox.com.conf

Apache

Nous allons maintenant créer le virtual host pour Apache pour pointer le répertoire d’installation d’Akeneo PIM sur votre nom de domaine. Nous utiliserons les valeurs /home/pim-community-standard pour le répertoire d’installation et domain-name.com pour le nom de domaine. Si vous êtes en local, vous pouvez utiliser akeneo-pim.local comme nom de domaine.

Et on remplit le fichier :

Et on active la configuration pour Apache :

On vérifie l’état du système

La sortie devrait ressembler à quelque chose comme ci-dessous :

Puis on rajoute le virtual host :

ou en local : 

Dans le cas de myVesta, rien est à faire !

Node 18

Pour consulter la version de Node.js que vous venez d’installer, tapez la commande :

Et il devrait sortir :

Yarn

On se connecte en root :

Pour consulter la version de Node.js que vous venez d’installer, tapez la commande :

On quitte root

Installation d’Akeneo PIM

On se logue en tant que pim7 :

Récupération des sources

Pour le répertoire d’installation, nous utiliserons /home/pim7/web/pim7.mcdtoolbox.com/public_html. C’est le répertoire utilisé pour la configuration myVesta, vous pouvez le changer si vous ne l’utilisez pas.

On peut installer Akeneo PIM avec composer en ayant installer le paquet correspondant :

Sans myVesta

Avec myVesta

Initialisation d’Akeneo PIM

On copie le fichier .env pour avoir le .env.local

Et on modifie les valeurs si dessous en prenant soin d’utiliser celles de votre base de donnée pour les variables APP_DATABASE. dans le fichier .env.local. Il ne sert à rien de modifier le fichier .env qui sera réinitialisé au moment du lancement de docker.

En effet, j’ai eu des erreurs de configurations lorsque je n’avais pas créé ce denier fichier. Le script d’installation ne pouvait pas créer la base de donnée.

C’est une erreur de configuration des variables d’environnement docker. Je ne suis pas un expert du domaine, mais idéalement il faudrait créer un environnement propre à l’installation.

Pour résoudre cela, prenez soin d’avoir les variables du .env.local suivantes :

Lancement d’Akeneo PIM en mode production

Si vous n’avez pas installer make :

Puis :

Si vous avez une erreur de php, modifier le Makefile et remplacer php par php8.1

On crée l’utilisateur principal pour se connecter :

Ou plus rapidement :

Nous pouvons maintenant accéder à Akeneo PIM par l’url http://domain-name.com avec l’utilisateur que nous venons de créer.

Démarrage de Elasticsearch au boot

Activation de SSL

Tâches CRON du PIM

Entrez dans le tableau des tâches automatisées de www-data :

Et rajouter les valeurs fournies par la documentation d’Akeneo :

Installation de Supervisor

Petit paquet très utile puisqu’il permet d’exécuter automatiquement les tâches de mis à jour des données du PIM.

Et remplir le fichier avec ces valeurs :

  • Modifier la valeur des chemins de la deuxième ligne
    • /path/to/php avec votre exécutable php
    • /path/to/your/pim avec votre dossier PIM
  • Modifier la valeur de my_user avec l’utilisateur qui utilise php-fpm (normalement, www-data)

Source : https://webkul.com/blog/process-control-in-akeneo/

Importation d’une version précédente

Les jobs

Pour importer les jobs (import/export) dune précédente versions, vous devrez importer la table SQL akeneo_batch_job_instance.

Les données

Très facile d’importer vos données à l’aide des outils natifs du pim 🙂

Erreurs Possibles

Erreur 500 sur une toute nouvelle installation

On attribue les droits www-data au répertoire du PIM

Database does not exist yet

Dans le fichier :

Bien vérifier que cette variable a pour valeur localhost :

Si l’erreur « No alive nodes found in your cluster » pendant l’installation

Dans le fichier :

Bien vérifier que cette variable a pour valeur localhost:9200 :

Script vendor/akeneo/pim-community-dev/std-build/install-required-files.sh handling the post-update-cmd event returned with error code 126

Exécuter la commande :

Si les importations et les exportations bloquent sur le status « Starting »

Voir le chapitre Installation de Supervisor

Que faire si Elasticsearch consomme trop de mémoire ?

Editez le fichier de configuration Java d’Elasticsearch :

Et on ajoute les lignes ci-dessous pour attribuer 4GB en minimum et maximum :

Vous pouvez conssulter le billet de blog de Ashnik qui discute de la manière d’optimiser la configuration d’Elasticsearch. Globalement, pour Elasticsearch, il est recommandé d’avoir 64GB de RAM et d’attribuer moins de 50% de la totalité de la mémoire disponible, c’est-à-dire  30GB environ. Mais pour des petites utilisations, 4GB est suffisant.

Si l’erreur « No alive nodes found in your cluster » est affichée après l’installation

Tester les commandes :

Que faire si Elasticsearch ne se lance pas au démarrage du serveur

Ouvrir le fichier :

Editer la ligne ci-dessous dans le section [Service]:

Activer le service :

Rédémarrer le service elasticsearch :

Source : https://stackoverflow.com/questions/58656747/elasticsearch-job-for-elasticsearch-service-failed

 

Catégories : LinuxPim

0 commentaire

Laisser un commentaire

Emplacement de l’avatar

Votre adresse e-mail ne sera pas publiée. Les champs obligatoires sont indiqués avec *