Page 1 sur 1

[RESOLU] Problème de migration 2.2.3 vers 2.5

Publié : 07 févr. 2024 - 11:09
par essaghir
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.

Re: Problème de migration 2.2.3 vers 2.5

Publié : 07 févr. 2024 - 14:59
par dcardon
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

Re: Problème de migration 2.2.3 vers 2.5

Publié : 07 févr. 2024 - 15:57
par essaghir
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

Re: Problème de migration 2.2.3 vers 2.5

Publié : 07 févr. 2024 - 17:44
par dcardon
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

Re: Problème de migration 2.2.3 vers 2.5

Publié : 08 févr. 2024 - 12:11
par dcardon
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

Re: Problème de migration 2.2.3 vers 2.5

Publié : 09 févr. 2024 - 11:03
par essaghir
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,

Re: Problème de migration 2.2.3 vers 2.5

Publié : 09 févr. 2024 - 12:02
par dcardon
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