Atualizando o Weblate

Atualizações de imagem Docker

A imagem oficial do Weblate no Docker (consulte Instalando usando Docker) integra todas as etapas de atualização. Normalmente, não é necessária nenhuma interação manual além de obter a versão mais recente (ou pelo menos a mais atual).

Instruções genéricas de atualização

Sempre procure por novas alterações em Requisitos de software antes de fazer a atualização. Depois que todos os requisitos forem instalados ou atualizados, verifique se o settings.py corresponde às alterações na configuração (consulte settings_example.py para obter os valores corretos).

Sempre verifique Instruções específicas da versão antes de fazer a atualização. Se estiver pulando alguma(s) versão(ões), certifique-se de seguir as instruções de todas as versões que estiver pulando durante essa atualização. Às vezes, é melhor atualizar gradualmente para uma versão intermediária para garantir uma migração tranquila. A atualização em várias versões deve funcionar, mas não é tão bem testada quanto as atualizações em uma única versão!

Nota

Sempre faça backup completo do banco de dados antes de atualizar, para que você possa reverter o banco de dados se a atualização falhar, consulte Fazendo backup e movendo o Weblate.

  1. Pare os processos WSGI e Celery para evitar que processos antigos continuem em execução durante a atualização. Caso contrário, mudanças incompatíveis no banco de dados podem ocorrer.

  2. Atualização do Weblate

    Para instalações pip, isso pode ser alcançado da seguinte forma:

    uv pip install -U "weblate[all]==version"
    

    Ou, se você quiser apenas obter a versão lançada mais recente:

    uv pip install -U "weblate[all]"
    

    Se você não quiser instalar todas as dependências opcionais, faça:

    uv pip install -U weblate
    

    Usando o checkout do Git, você precisa buscar o novo código-fonte e atualizar sua instalação:

    cd weblate-src
    git pull
    # Update Weblate inside your virtualenv
    . ~/weblate-env/bin/uv pip install -e '.[all]'
    # Install dependencies directly when not using virtualenv
    uv pip install --upgrade -e .
    # Install optional dependencies directly when not using virtualenv
    uv pip install --upgrade -e '.[all]'
    
  3. Novas versões do Weblate podem ter novos Dependências Python, verifique se eles abrangem as funcionalidades que você deseja.

  4. Atualize o arquivo de configuração seguindo settings_example.py ou Instruções específicas da versão.

  5. Atualizar o banco de dados:

    weblate migrate --noinput
    
  6. Colete arquivos estáticos atualizados (veja Executando servidor e Servindo arquivos estáticos):

    weblate collectstatic --noinput --clear
    
  7. Compactar arquivos JavaScript e CSS (opcional, veja Comprimindo os ativos do cliente):

    weblate compress
    
  8. Se você estiver executando uma instalação a partir do Git, também deverá gerar novamente os arquivos de localidade sempre que fizer uma atualização. Você pode fazer isso invocando:

    weblate compilemessages
    
  9. Verifique que sua configuração é sana (ver também Configuração de produção):

    weblate check --deploy
    
  10. Reinicie o worker do Celery (veja Tarefas de fundo usando Celery).

Instruções específicas da versão

Alterado na versão 5.0: Instruções específicas da versão agora estão incluídas nas notas de lançamento, consulte Weblate 5.8.1.

Atualize de uma versão principal mais antiga

Atualizações entre versões principais não são suportadas. Sempre atualize para o nível de patch mais recente da versão principal inicial. As atualizações que ignoram esta etapa não são suportadas e serão interrompidas.

  • Se estiver atualizando a partir da versão 2.x, sempre atualize primeiro para a versão 3.0.1.

  • Se estiver atualizando a partir da versão 3.x, sempre atualize primeiro para a versão 4.0.4.

  • Se estiver atualizando a partir da versão 4.x, sempre atualize primeiro para a versão 5.0.2.

Migrando de outros bancos de dados para o PostgreSQL

Se você não estiver executando o Weblate com um banco de dados diferente do PostgreSQL, considere a possibilidade de migrar para o PostgreSQL para obter melhor desempenho, executando as etapas a seguir. Lembre-se de interromper os servidores Web e Celery antes, caso contrário, você poderá acabar com dados inconsistentes.

Criando um banco de dados no PostgreSQL

Normalmente, é uma boa ideia executar o Weblate em um banco de dados separado e em uma conta de usuário separada:

# If PostgreSQL was not installed before, set the main password
sudo -u postgres psql postgres -c "\password postgres"

# Create a database user called "weblate"
sudo -u postgres createuser -D -P weblate

# Create the database "weblate" owned by "weblate"
sudo -u postgres createdb -E UTF8 -O weblate weblate

Migrando para PostgreSQL usando pgloader

O pgloader é uma ferramenta de migração genérica para migrar dados para o PostgreSQL. Você pode usá-lo para migrar seu banco de dados do Weblate.

  1. Ajuste seu settings.py para usar o PostgreSQL como banco de dados.

  2. Migre o esquema no banco de dados PostgreSQL:

    weblate migrate
    weblate sqlflush | weblate dbshell
    

3. Run the pgloader to transfer the data. The following script can be used to migrate the database, but you might want to learn more about pgloader to better understand what it does, and tweak it to match your setup:

LOAD DATABASE
     FROM      mysql://weblate:password@localhost/weblate
     INTO postgresql://weblate:password@localhost/weblate

WITH include no drop, truncate, create no tables, create no indexes, no foreign keys, disable triggers, reset sequences, data only

ALTER SCHEMA 'weblate' RENAME TO 'public'
;

Migrando de Pootle

Como o Weblate foi originalmente escrito como um substituto para o Pootle, há suporte para a migração das contas de usuário a partir dele. Você pode despejar os usuários do Pootle e importá-los usando importusers.