[RESUELTO] Problema de migración de 2.2.3 a 2.5

Preguntas sobre el servidor WAPT / Solicitudes y ayuda relacionadas con el servidor WAPT
Reglas del foro
Reglas del foro de la comunidad
* Soporte en inglés en www.reddit.com/r/wapt
* El soporte de la comunidad en francés está disponible en este foro
* Por favor, anteponga [RESUELTO] al título del tema si está resuelto.
* Por favor, no edite un tema que esté etiquetado como [RESUELTO]. Abra un nuevo tema haciendo referencia al anterior.
* Especifique la versión de WAPT instalada, la versión completa y el número de compilación (2.2.1.11957 / 2.2.2.12337 / etc.), así como la edición Enterprise/Discovery.
* Las versiones 1.8.2 y anteriores ya no son compatibles. Las únicas preguntas aceptadas sobre la versión 1.8.2 están relacionadas con la actualización a una versión compatible (2.1, 2.2, etc.).
* Especifique el sistema operativo del servidor (Linux/Windows) y la versión (Debian Buster/Bullseye - CentOS 7 - Windows Server 2012/2016/2019).
* Especifique el sistema operativo de la máquina de administración/creación de paquetes y de la máquina con el agente problemático, si corresponde (Windows 7/10/11/Debian 11/etc.).
* Evite hacer varias preguntas al abrir un tema, ya que podría ser ignorado. Si hay varios temas, ábralos por separado, preferiblemente uno tras otro y no todos a la vez (es decir, no sature el foro con spam).
* Incluya fragmentos de código, capturas de pantalla y otras imágenes directamente en la publicación. Los enlaces a Pastebin, Bitly y otros sitios de terceros serán eliminados sistemáticamente.
* Como en cualquier foro comunitario, el soporte es proporcionado voluntariamente por los miembros. Si necesita soporte comercial, puede comunicarse con el departamento de ventas de Tranquil IT al 02.40.97.57.55.
Bloqueado
essaghir
Mensajes: 5
Inscripción: 7 de febrero de 2024 - 10:58

7 de febrero de 2024 - 11:09

Buen día,

ID del distribuidor: Debian
Descripción: Debian GNU/Linux 10 (buster)
Lanzamiento: 10
Nombre en clave: Buster
Postgres 11.2

La migración falló, con los registros a continuación:

Código: Seleccionar todo

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.
¿Podrías ayudarme a depurar el problema?

Gracias de antemano por sus respuestas.
Avatar de usuario
dcardón
Experto en WAPT
Mensajes: 1908
Inscripción: 18 de junio de 2014 - 09:58
Ubicación: Saint Sébastien sur Loire
Contacto :

7 de febrero de 2024 - 14:59

Hola Mohamed,

¿Puedes verificar que efectivamente es la versión 11 de PostgreSQL la que se está ejecutando actualmente en tu servidor?
Al actualizar un sistema Debian, la versión anterior de Postgres no se actualiza automáticamente.

Código: Seleccionar todo

sudo -u postgres psql template1
    SHOW server_version;

El comando se puede corregir con un CAST, pero esto no debería ser necesario en una versión de Postgres >=10...

Atentamente,

Denis
Denis Cardon - Tranquil IT
¡Comparte tus experiencias en WAPT! Envíanos las URL de tus blogs y artículos en la "Tu opinión del foro y los publicaremos en el de WAPT
essaghir
Mensajes: 5
Inscripción: 7 de febrero de 2024 - 10:58

7 de febrero de 2024 - 15:57

Hola Denis,

A continuación se muestra el resultado del comando:

Código: Seleccionar todo

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)
Parece ser la versión 11.

Estoy disponible si necesita más información.

Atentamente,
Mahoma
Avatar de usuario
dcardón
Experto en WAPT
Mensajes: 1908
Inscripción: 18 de junio de 2014 - 09:58
Ubicación: Saint Sébastien sur Loire
Contacto :

7 de febrero de 2024 - 17:44

Hola Mohamed,

hemos logrado reproducir el problema internamente. La columna ya está en varchar[] cuando se llama a la función string_array... Es bastante extraño. El problema solo ocurre al actualizar de la versión 2.2.3 a la 2.5, no al revés. Te mantendremos informado.

Saludos cordiales,

Denis
Denis Cardon - Tranquil IT
¡Comparte tus experiencias en WAPT! Envíanos las URL de tus blogs y artículos en la "Tu opinión del foro y los publicaremos en el de WAPT
Avatar de usuario
dcardón
Experto en WAPT
Mensajes: 1908
Inscripción: 18 de junio de 2014 - 09:58
Ubicación: Saint Sébastien sur Loire
Contacto :

8 de febrero de 2024 - 12:11

Hola Mohamed,

Mientras espera la compilación nocturna, puede comentar las siguientes líneas en el archivo /opt/wapt/waptserver/model.py (líneas 2673 a 2680). Este problema afecta a los usuarios que actualicen desde la versión 2.2.3 o anterior de WAPT. No afecta a los usuarios que actualicen desde la versión 2.3 o 2.4

Código: Seleccionar todo

#    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,',');")
luego reinicie el servidor wapt

Código: Seleccionar todo

systemctl restart waptserver
Atentamente,

Denis
Denis Cardon - Tranquil IT
¡Comparte tus experiencias en WAPT! Envíanos las URL de tus blogs y artículos en la "Tu opinión del foro y los publicaremos en el de WAPT
essaghir
Mensajes: 5
Inscripción: 7 de febrero de 2024 - 10:58

9 de febrero de 2024 - 11:03

Hola Denis,
gracias por tu ayuda. Con la modificación, la consola se inicia en la versión 2.5.3.15292.

Sin embargo, cuando ejecuto "Build and send waptupgrade", obtengo el siguiente error: "-0 no es una cadena de versión válida". ¿

Tienes alguna idea de por qué?

Atentamente,
Avatar de usuario
dcardón
Experto en WAPT
Mensajes: 1908
Inscripción: 18 de junio de 2014 - 09:58
Ubicación: Saint Sébastien sur Loire
Contacto :

9 de febrero de 2024 - 12:02 p. m

Hola Mohamed,

gracias por tus comentarios. La solución para actualizar desde la versión 2.2.3 estará disponible en la próxima versión, la 2.5.4.

Para otras preguntas, por favor, abre un nuevo hilo (consulta las normas del foro: un tema por hilo).

Marco este hilo como RESUELTO.

Saludos,

Denis
Denis Cardon - Tranquil IT
¡Comparte tus experiencias en WAPT! Envíanos las URL de tus blogs y artículos en la "Tu opinión del foro y los publicaremos en el de WAPT
Bloqueado