Problema com a atualização do postgres

Estou tentando ajudar alguém que se recusou a atualizar para o PG13 e agora tem um certificado SSL expirado.

Isso pode ser dificultado por causa de Apt-get update fails inside container yarn repo not signed - #5 by pfaffman, mas modifiquei os templates pg12 e pg13 para que funcionem, mas não consigo fazer a atualização e não consigo reconstruir com o template pg12.

Aqui está o que acontece quando tentei fazer a atualização:

                                     
fixing permissions on existing directory /var/lib/postgresql/12/main ... ok          
creating subdirectories ... ok
selecting dynamic shared memory implementation ... posix
selecting default max_connections ... 100                                                                                                              
selecting default shared_buffers ... 128MB
selecting default time zone ... Etc/UTC                              
creating configuration files ... ok
running bootstrap script ... ok
performing post-bootstrap initialization ... ok
syncing data to disk ... ok
                                     
Success. You can now start the database server using:
                                                                                                                                                       
    pg_ctlcluster 12 main start                                                                                                                        
                                                                           
update-alternatives: warning: forcing reinstallation of alternative /usr/share/postgresql/13/man/man1/postmaster.1.gz because link group postmaster.1.g
z is broken                                                                                                                                            
invoke-rc.d: could not determine current runlevel
invoke-rc.d: policy-rc.d denied execution of start.             
Processing triggers for postgresql-common (246.pgdg110+1) ...
Building PostgreSQL dictionaries from installed myspell/hunspell packages...
Removing obsolete dictionary files:                                                                                                                    
Stopping PostgreSQL 12 database server: main.                                                                                                          
Stopping PostgreSQL 13 database server: main.                                                                                                          
Performing Consistency Checks               -----------------------------                                                                                                                          
Checking cluster versions                                   ok                                                                                         
Checking database user is the install user                  ok                                                                                         
Checking database connection settings                       ok                                                                                         
Checking for prepared transactions                          ok                                                                                         
Checking for system-defined composite types in user tables  ok                                                                                         
Checking for reg* data types in user tables                 ok                                                                                         
Checking for contrib/isn with bigint-passing mismatch       ok                                                                                         
Creating dump of global objects                             ok                                                                                         
Creating dump of database schemas                                                                                                                      
  discourse                                                                                                                                            
                                                                                                                                                       
*failure*                                                                                                                                              
                                                                                                                                                       
Consult the last few lines of "pg_upgrade_dump_16566.log" for
the probable cause of the failure.
Failure, exiting
-------------------------------------------------------------------------------------
UPGRADE OF POSTGRES FAILED
                                                                                                                                                       
Please visit https://meta.discourse.org/t/postgresql-13-update/172563 for support.
                                                                                                                                                       
You can run ./launcher start app to restart your app in the meanwhile

Tentar reconstruir sem a atualização tem coisas como as abaixo quando tenta migrar o banco de dados:

PG::InsufficientPrivilege: ERROR:  permission denied to create extension "unaccent"                                                                    

Acho que terei que reverter para uma instalação limpa e o último backup, que tem vários dias.

Você não pode adicionar o abaixo a hooks para criar a extensão unaccent se ela estiver faltando?

after_postgres:
    - exec: su postgres -c 'psql discourse -c "create extension if not exists unaccent;"'
3 curtidas

Parece um bom plano! Vou verificar pela manhã. Obrigado

1 curtida

Parece que isso resolveu! Tive que adicioná-lo ao pg12 e ao postgres.

Bem, resolveu o suficiente para fazê-lo funcionar novamente com o PG12, mas nunca consegui fazer o upgrade do PG13 funcionar. Fiz um backup, movi as coisas do postgres para um diretório de backup, reconstruí e restaurei o backup.

1 curtida

Este tópico foi fechado automaticamente 30 dias após a última resposta. Novas respostas não são mais permitidas.