Antes de comenzar
Asegúrate de que la versión del operador de Kubernetes de AlloyDB Omni sea
1.4.0
. Para actualizar la versión del operador de AlloyDB Omni, consulta Migra a la versión más reciente del operador de Kubernetes de AlloyDB Omni.Asegúrate de tener al menos 5 GB de espacio libre en el disco.
Si ejecutas sistemas de copias de seguridad externos o remotos, realiza una copia de seguridad completa y pausa las copias de seguridad programadas para evitar que se realicen copias de seguridad durante el proceso de actualización.
En los entornos de alta disponibilidad (HA) y recuperación ante desastres (DR), desacopla tus clústeres de bases de datos antes de actualizarlos.
Actualiza tu versión de AlloyDB Omni
Para actualizar tu versión de AlloyDB Omni con pg_upgrade
, realiza una de las siguientes acciones:
Ejecuta la secuencia de comandos de Bash que realiza la actualización por ti.
Secuencia de comandos de actualización
Puedes encontrar una secuencia de comandos que realiza los pasos de actualización manual en las muestras de AlloyDB Omni en GitHub.
Para usar la secuencia de comandos de actualización, descárgala y ejecuta el siguiente comando:
./MVU.sh 16.3.0 1.4.0 NAME NAMESPACE
Reemplaza las siguientes variables:
- NAME: Es el nombre de tu clúster de base de datos.
- NAMESPACE: Es el espacio de nombres de tu clúster de base de datos.
Pasos para la actualización manual
Crea una copia de seguridad de tus datos para evitar la pérdida de datos.
Finaliza todos los procesos de replicación. Esto incluye la replicación física que se usa para la alta disponibilidad (HA) y la resiliencia de los datos (DR), así como todos los flujos de replicación lógica.
Anota tu clúster de base de datos para especificar una actualización manual de la versión.
kubectl annotate dbclusters.alloydbomni.dbadmin.goog NAME dbs.dbadmin.goog.com/manualmvu=true
Reemplaza la siguiente variable:
- NAME: Es el nombre de tu clúster de base de datos.
Detén el proceso de PostgreSQL para que se puedan mover los datos para la actualización.
k exec -ti POD_NAME -- /bin/Bash # Shut down postgres postgres@POD_NAME:~$ supervisorctl.par stop postgres postgres@POD_NAME:~$ mkdir /mnt/disks/pgsql/15; mv /mnt/disks/pgsql/data /mnt/disks/pgsql/15/data; cp -r /usr/lib/postgresql/15/bin /mnt/disks/pgsql/15/.; cp -r /usr/lib/postgresql/15/lib /mnt/disks/pgsql/15/.; cp -r /usr/share/postgresql/15 /mnt/disks/pgsql/15/share; rm /mnt/disks/pgsql/15/share/postgresql.conf.sample; cp /usr/share/postgresql/postgresql.conf.sample /mnt/disks/pgsql/15/share/postgresql.conf.sample; chmod 2740 /mnt/disks/pgsql/15/data
Reemplaza la siguiente variable:
- POD_NAME: Es el nombre de tu Pod.
Aplica parches a tu clúster de base de datos para que use la versión
16.3.0
y a tus agentes del plano de control (CPA) para que usen la versión1.4.0
.kubectl patch dbclusters.alloydbomni.dbadmin.goog NAME --type=merge -p '{"spec":{"databaseVersion":"16.3.0","controlPlaneAgentsVersion":"omni_control_plane_agents_version"}}'
Reemplaza la siguiente variable:
- NAME: Es el nombre de tu clúster de base de datos.
Crea un clúster de base de datos vacío para la nueva versión de AlloyDB Omni.
k exec -ti POD_NAME -- /bin/Bash postgres@POD_NAME:~$ supervisorctl.par stop postgres # Initialize a new, empty database cluster for the new version. postgres@POD_NAME:~$ rm -fr /mnt/disks/pgsql/data; initdb -D /mnt/disks/pgsql/data -U alloydbadmin --data-checksums --encoding=UTF8 --locale=C --locale-provider=icu --icu-locale=und-x-icu --auth-host=trust --auth-local=reject; cd ~
Reemplaza la siguiente variable:
- POD_NAME: Es el nombre de tu Pod.
Modifica
pg_hba.conf
en tu clúster de base de datos existente para proporcionar al proceso de actualización los permisos y las conexiones que necesita.# Backup pg_hba.conf of the pg15 cluster postgres@POD_NAME:~$ cp /mnt/disks/pgsql/15/data/pg_hba.conf /mnt/disks/pgsql/15/data/pg_hba.conf.bak # Update pg15 configurations postgres@POD_NAME:~$ echo "local all all trust" >> /mnt/disks/pgsql/15/data/pg_hba.conf; echo "host all all 127.0.0.1/32 trust" >> /mnt/disks/pgsql/15/data/pg_hba.conf
Reemplaza la siguiente variable:
- POD_NAME: Es el nombre de tu Pod.
Modifica
pg_hba.conf
en el nuevo clúster de bases de datos para proporcionar al proceso de actualización los permisos y las conexiones que necesita.postgres@POD_NAME:~$ rm /mnt/disks/pgsql/data/pg_hba.conf; echo "local all all trust" >> /mnt/disks/pgsql/data/pg_hba.conf; echo "host all all 127.0.0.1/32 trust" >> /mnt/disks/pgsql/data/pg_hba.conf; chmod 2740 /mnt/disks/pgsql/15/data
Reemplaza la siguiente variable:
- POD_NAME: Es el nombre de tu Pod.
Actualiza tu clúster de base de datos.
# (optional) Make sure postgres is stopped postgres@POD_NAME:~$ supervisorctl.par stop postgres # (optional) Check to verify that data can be upgraded. postgres@POD_NAME:~$ pg_upgrade -U alloydbadmin --check -b /mnt/disks/pgsql/15/bin -B /usr/lib/postgresql/16/bin -d /mnt/disks/pgsql/15/data -D /mnt/disks/pgsql/data --link -v postgres@POD_NAME:~$ pg_upgrade -U alloydbadmin -b /mnt/disks/pgsql/15/bin -B /usr/lib/postgresql/16/bin -d /mnt/disks/pgsql/15/data -D /mnt/disks/pgsql/data --link -v # Need to recover pg15 configurations postgres@POD_NAME:~$ cp /mnt/disks/pgsql/15/data/pg_hba.conf.bak /mnt/disks/pgsql/data/pg_hba.conf; cp -r /mnt/disks/pgsql/15/data/postgresql.conf /mnt/disks/pgsql/data/.; cp -r /mnt/disks/pgsql/15/data/postgresql.conf.d /mnt/disks/pgsql/data/.; cp -r /mnt/disks/pgsql/15/data/parambackup /mnt/disks/pgsql/data/. # Start postgres postgres@POD_NAME:~$ supervisorctl.par start postgres # Clean up backup data postgres@POD_NAME:~$ rm -fr /mnt/disks/pgsql/15/
Reemplaza la siguiente variable:
- POD_NAME: Es el nombre de tu Pod.
Quita la anotación de actualización manual de la versión de tu clúster de base de datos.
kubectl annotate dbclusters.alloydbomni.dbadmin.goog NAME dbs.dbadmin.goog.com/manualmvu-
Reemplaza la siguiente variable:
- NAME: Es el nombre de tu clúster de base de datos.
Reanuda las operaciones normales y vuelve a habilitar las copias de seguridad, los planes de copias de seguridad o los procesos de replicación que se inhabilitaron en los pasos del uno al tres.