[RESOLU] Problème de migration 2.2.3 vers 2.5

Question about WAPT Server / Requêtes et aides autour du serveur Wapt
Règles du forum
Règles du forum communautaire
* English support on www.reddit.com/r/wapt
* Le support communautaire en français se fait sur ce forum
* Merci de préfixer le titre du topic par [RESOLU] s'il est résolu.
* Merci de ne pas modifier un topic qui est taggé [RESOLU]. Ouvrez un nouveau topic en référençant l'ancien
* Préciser version de WAPT installée, version complète ET numéro de build (2.2.1.11957 / 2.2.2.12337 / etc.) AINSI QUE l'édition Enterprise / Discovery
* Les versions 1.8.2 et antérieures ne sont plus maintenues. Les seules questions acceptées vis à vis de la version 1.8.2 sont liés à la mise à jour vers une version supportée (2.1, 2.2, etc.)
* Préciser OS du serveur (Linux / Windows) et version (Debian Buster/Bullseye - CentOS 7 - Windows Server 2012/2016/2019)
* Préciser OS de la machine d'administration/création des paquets et de la machine avec l'agent qui pose problème le cas échéant (Windows 7 / 10 / 11 / Debian 11 / etc.)
* Eviter de poser plusieurs questions lors de l'ouverture de topic, sinon il risque d'être ignorer. Si plusieurs sujet, ouvrir plusieurs topic, et de préférence les uns après les autres et pas tous en même temps (ie ne pas spammer le forum).
* Inclure directement les morceaux de code, les captures d'écran et autres images directement dans le post. Les liens vers les pastebin, les bitly et autres sites tierces seront systématiquement supprimés.
* Comme tout forum communautaire, le support est fait bénévolement par les membres. Si vous avez besoin d'un support commercial, vous pouvez contacter le service commercial Tranquil IT au 02.40.97.57.55
essaghir
Messages : 5
Inscription : 07 févr. 2024 - 10:58

07 févr. 2024 - 11:09

Bonjour,

Distributor ID: Debian
Description: Debian GNU/Linux 10 (buster)
Release: 10
Codename: buster
Postgres 11.2

La migration échoue avec les logs ci-dessous :

Code : Tout sélectionner

2024-02-07 10:52:53,126 INFO Migrating from 2.4.0.0 to 2.4.2.0
Traceback (most recent call last):
  File "/opt/wapt/lib/python3.8/site-packages/peewee.py", line 3144, in execute_sql
    cursor.execute(sql, params or ())
psycopg2.errors.UndefinedFunction: function string_to_array(character varying[], unknown) does not exist
LINE 1: ...kages ALTER COLUMN target_os TYPE varchar[] USING string_to_...
                                                             ^
HINT:  No function matches the given name and argument types. You might need to add explicit type casts.


During handling of the above exception, another exception occurred:

Traceback (most recent call last):
  File "<string>", line 1, in <module>
  File "/opt/wapt/waptserver/model.py", line 2677, in upgrade_db_structure
    wapt_db.execute_sql("ALTER TABLE packages ALTER COLUMN target_os TYPE varchar[] USING string_to_array(target_os,',');")
  File "/opt/wapt/lib/python3.8/site-packages/peewee.py", line 3151, in execute_sql
    self.commit()
  File "/opt/wapt/lib/python3.8/site-packages/peewee.py", line 2917, in __exit__
    reraise(new_type, new_type(exc_value, *exc_args), traceback)
  File "/opt/wapt/lib/python3.8/site-packages/peewee.py", line 190, in reraise
    raise value.with_traceback(tb)
  File "/opt/wapt/lib/python3.8/site-packages/peewee.py", line 3144, in execute_sql
    cursor.execute(sql, params or ())
peewee.ProgrammingError: function string_to_array(character varying[], unknown) does not exist
LINE 1: ...kages ALTER COLUMN target_os TYPE varchar[] USING string_to_...
                                                             ^
HINT:  No function matches the given name and argument types. You might need to add explicit type casts.
Pouvez vous svp m'aider à déboger le problème ?

D'avance merci pour vos réponses.
Avatar de l’utilisateur
dcardon
Expert WAPT
Messages : 1412
Inscription : 18 juin 2014 - 09:58
Localisation : Saint Sébastien sur Loire
Contact :

07 févr. 2024 - 14:59

Bonjour Mohamed,

est ce que vous pouvez vérifier que c'est bien la version 11 de postgres qui tourne actuellement sur votre serveur?
Quand on upgrade une Debian l'ancienne version de Postgres n'est pas automatiquement upgradée.

Code : Tout sélectionner

sudo -u postgres psql template1
    SHOW server_version;

On peut corriger la commande avec un CAST, mais ça ne devrait pas être nécessaire sur une version Postgres >=10...

Cordialement,

Denis
Denis Cardon - Tranquil IT
Communiquez autour de vous sur WAPT! Envoyez nous vos url de blog et d'articles dans la catégorie votre avis du forum, nous les mettrons en avant sur le site WAPT
essaghir
Messages : 5
Inscription : 07 févr. 2024 - 10:58

07 févr. 2024 - 15:57

Bonjour Denis,

Ci dessous le résultat de la commande :

Code : Tout sélectionner

could not change directory to "/root": Permission denied
psql (11.22 (Debian 11.22-0+deb10u1))
Type "help" for help.

template1=# SHOW server_version;
         server_version
--------------------------------
 11.22 (Debian 11.22-0+deb10u1)
A priori c'est bien une version 11.

Je suis à votre disposition si vous avez besoin d'autre information.

Cordialement,
Mohamed
Avatar de l’utilisateur
dcardon
Expert WAPT
Messages : 1412
Inscription : 18 juin 2014 - 09:58
Localisation : Saint Sébastien sur Loire
Contact :

07 févr. 2024 - 17:44

Bonjour Mohamed,

on a réussi à reproduire le problème en interne. La colonne est déjà en varchar[] quand la fonction string_arrray est lancé... C'est assez curieux. Le problème ne se présente que si l'on upgrade d'une 2.2.3 à une 2.5, pas si l'on upgrade d'une 2.3 vers une 2.5. On vous tiens au courant.

Cordialement,

Denis
Denis Cardon - Tranquil IT
Communiquez autour de vous sur WAPT! Envoyez nous vos url de blog et d'articles dans la catégorie votre avis du forum, nous les mettrons en avant sur le site WAPT
Avatar de l’utilisateur
dcardon
Expert WAPT
Messages : 1412
Inscription : 18 juin 2014 - 09:58
Localisation : Saint Sébastien sur Loire
Contact :

08 févr. 2024 - 12:11

Bonjour Mohamed,

en attendant une nightly, vous pouvez commenter les lignes suivantes dans le fichier /opt/wapt/waptserver/model.py (ligne 2673 à 2680). Ce problème se pose pour les utilisateurs qui upgradent depuis une version WAPT 2.2.3 ou antérieure. Ca n'impacte pas les utilisateurs upgradant depuis une version 2.3 ou 2.4

Code : Tout sélectionner

#    next_version = '2.4.2.0'
#    if get_db_version() < next_version:
#        with wapt_db.atomic():
#            logger.info("Migrating from %s to %s" % (get_db_version(), next_version))
#            wapt_db.execute_sql("ALTER TABLE packages ALTER COLUMN target_os TYPE varchar[] USING string_to_array(target_os,',');")
#            wapt_db.execute_sql("ALTER TABLE packages ALTER COLUMN licence TYPE varchar[] USING string_to_array(licence,',');")
#            wapt_db.execute_sql("ALTER TABLE packages ALTER COLUMN locale TYPE varchar[] USING string_to_array(locale,',');")
#            wapt_db.execute_sql("ALTER TABLE packages ALTER COLUMN architecture TYPE varchar[] USING string_to_array(architecture,',');")
puis relancer le serveur wapt

Code : Tout sélectionner

systemctl restart waptserver
Cordialement,

Denis
Denis Cardon - Tranquil IT
Communiquez autour de vous sur WAPT! Envoyez nous vos url de blog et d'articles dans la catégorie votre avis du forum, nous les mettrons en avant sur le site WAPT
essaghir
Messages : 5
Inscription : 07 févr. 2024 - 10:58

09 févr. 2024 - 11:03

Bonjour Denis,
Merci pour votre aide, avec la modif la console se lance en 2.5.3.15292.

Par contre quand je lance "Construire et envoyer waptupgrade" j'ai une erreur "-0 is not a valid version string"

Avez-vous une idée ?

Cordialement,
Avatar de l’utilisateur
dcardon
Expert WAPT
Messages : 1412
Inscription : 18 juin 2014 - 09:58
Localisation : Saint Sébastien sur Loire
Contact :

09 févr. 2024 - 12:02

Bonjour Mohamed,

merci pour le retour. Le correctif pour l'upgrade depuis une version 2.2.3 sera disponible dans la prochaine release 2.5.4.

Pour les autres questions, merci d'ouvrir un nouveau topic (cf. forum rules : un seul sujet par topic).

Je passe ce topic en RESOLU.

Cordialement,

Denis
Denis Cardon - Tranquil IT
Communiquez autour de vous sur WAPT! Envoyez nous vos url de blog et d'articles dans la catégorie votre avis du forum, nous les mettrons en avant sur le site WAPT
Verrouillé