Última Versão do Discourse quebra rebuild, Porta Redis já em uso

SO: Ubuntu 20.04
Servidor: vServer 4 núcleos, 16 GB
Disco: SSD 160GB

Atualizei recentemente para a versão mais recente do Discourse. Agora estou enfrentando o problema de que o Discourse relata que a porta 6379 está em uso, e portanto o container não pode ser construído:

Quando verifico todas as portas em uso, essa porta está livre:

Algo na verificação do Discourse falha ao reconhecer que a porta está livre.
No Docker, posso ver que apenas o container do Discourse foi iniciado e tudo mais falha:

Esse problema realmente virou um paradoxo.
O Discourse inicia o processo do redis-server no Docker e depois falha, porque já havia iniciado o processo:

Tenho uma instalação principal do Redis rodando na máquina hospedeira, mas ela está na porta 6800, então não deveria interferir.

Parece claramente que a verificação falha consigo mesma, porque o Redis inicia com sucesso e depois reporta falha: endereço em uso:

Você pode compartilhar seu arquivo app.yml, por favor?

3 curtidas

Sim, claro, obrigado por analisar :smiley:. Aqui está meu app.yml:

## este é o modelo de container Docker Discourse tudo-em-um, autônomo
##
## Após fazer alterações neste arquivo, você DEVE reconstruir
## /var/discourse/launcher rebuild app
##
## TENHA *MUITO* CUIDADO AO EDITAR!
## ARQUIVOS YAML SÃO SUPER SUPER SENSÍVEIS A ERROS DE ESPAÇAMENTO OU ALINHAMENTO!
## visite http://www.yamllint.com/ para validar este arquivo conforme necessário

templates:
  - "templates/postgres.template.yml"
  - "templates/redis.template.yml"
  - "templates/web.template.yml"
  - "templates/web.ratelimited.template.yml"
## Descomente estas duas linhas se desejar adicionar o Lets Encrypt (https)
  #- "templates/web.ssl.template.yml"
  #- "templates/web.letsencrypt.ssl.template.yml"

## quais portas TCP/IP este container deve expor?
## Se você deseja que o Discourse compartilhe uma porta com outro servidor web como Apache ou nginx,
## veja https://meta.discourse.org/t/17247 para detalhes
expose:
  - "12080:80"   # http
  - "12443:443" # https

params:
  db_default_text_search_config: "pg_catalog.english"

  ## Defina db_shared_buffers para no máximo 25% da memória total.
  ## será definido automaticamente pelo bootstrap com base na RAM detectada, ou você pode substituir
  db_shared_buffers: "4096MB"

  ## pode melhorar o desempenho de ordenação, mas aumenta o uso de memória por conexão
  #db_work_mem: "40MB"

  ## Qual revisão do Git este container deve usar? (padrão: tests-passed)
  #version: tests-passed

env:
  LANG: en_US.UTF-8
  # DISCOURSE_DEFAULT_LOCALE: en

  ## Quantas solicitações web simultâneas são suportadas? Depende da memória e dos núcleos da CPU.
  ## será definido automaticamente pelo bootstrap com base nas CPUs detectadas, ou você pode substituir
  UNICORN_WORKERS: 8

  ## TODO: O nome de domínio ao qual esta instância do Discourse responderá
  DISCOURSE_HOSTNAME: discourse.forum

  ## Descomente se quiser que o container seja iniciado com o mesmo
  ## nome de host (-h option) especificado acima (padrão "$hostname-$config")
  #DOCKER_USE_HOSTNAME: true

  ## TODO: Lista de e-mails separados por vírgula que serão feitos administradores e desenvolvedores
  ## no cadastro inicial exemplo 'user1@example.com,user2@example.com'
  DISCOURSE_DEVELOPER_EMAILS: 'developer@email'

  ## TODO: O servidor de e-mail SMTP usado para validar novas contas e enviar notificações
  DISCOURSE_SMTP_ADDRESS: mailserver
  DISCOURSE_SMTP_PORT: 587
  DISCOURSE_SMTP_USER_NAME: email@email
  DISCOURSE_SMTP_PASSWORD: "****"
  #DISCOURSE_SMTP_AUTHENTICATION: plain
  #DISCOURSE_SMTP_ENABLE_START_TLS: true           # (opcional, padrão true)

  ## Se você adicionou o modelo Lets Encrypt, descomente abaixo para obter um certificado SSL gratuito
  #LETSENCRYPT_ACCOUNT_EMAIL: me@example.com

  ## O endereço do CDN para esta instância do Discourse (configurado para buscar)
  ## veja https://meta.discourse.org/t/14857 para detalhes
  #DISCOURSE_CDN_URL: //discourse-cdn.example.com

## O container Docker é sem estado; todos os dados são armazenados em /shared
volumes:
  - volume:
      host: /var/discourse/shared/standalone
      guest: /shared
  - volume:
      host: /var/discourse/shared/standalone/log/var-log
      guest: /var/log

## Plugins vão aqui
## veja https://meta.discourse.org/t/19157 para detalhes
hooks:
  after_code:
    - exec:
        cd: $home/plugins
        cmd:
          - git clone https://github.com/discourse/docker_manager.git
          - git clone https://github.com/angusmcleod/discourse-question-answer.git
          - git clone https://github.com/discourse/discourse-solved.git
          - git clone https://github.com/discourse/discourse-voting.git
          - git clone https://github.com/gdpelican/retort.git
          - git clone https://github.com/davidtaylorhq/discourse-whos-online.git
          - git clone https://github.com/vinkas0/discourse-navigation.git
          - git clone https://github.com/discourse/discourse-spoiler-alert.git
          - git clone https://github.com/iunctis/discourse-formatting-toolbar.git
          - git clone https://github.com/discourse/discourse-tooltips.git
          - git clone https://github.com/gdpelican/babble.git
          - git clone https://github.com/paviliondev/discourse-quick-messages.git
          - git clone https://github.com/worldismine/PM-Scanner.git
          - git clone https://github.com/paviliondev/discourse-ratings.git
          - git clone https://github.com/discourse/discourse-calendar.git
          - git clone https://github.com/jannolii/discourse-topic-trade-buttons.git

## Quaisquer comandos personalizados para executar após a construção
run:
  - exec: echo "Início dos comandos personalizados"
  ## Se você quiser definir o endereço de e-mail 'De' para seu primeiro registro, descomente e altere:
  ## Após receber o primeiro e-mail de cadastro, comente novamente a linha. Ele só precisa ser executado uma vez.
  ##- exec: rails r "SiteSetting.notification_email='email@email"
  - exec: echo "Fim dos comandos personalizados"
1 curtida

Você também pode postar a saída completa da reconstrução?

Tenho quase certeza de que as linhas que você vê ocorrem em toda reconstrução desde sempre e não bloqueiam a reconstrução de forma alguma, já que estamos apenas garantindo que o Redis esteja rodando em dois hooks diferentes. Seu problema está em outro lugar.

1 curtida

Claro. Se precisar de outros logs, posso fornecê-los :slight_smile:
Eu os postei no Pastebin, porque são mais de 3226 linhas e excedem o limite de postagem do fórum: Discourse Rebuild Log - Pastebin.com

Essa saída mostra uma reconstrução bem-sucedida…

Seu site não está funcionando na porta 12080?

1 curtida

Sim, o site está sendo reconstruído com sucesso novamente.
Descobri a causa do problema, que impedia o carregamento adequado do site no meu computador.
O erro estava em um certificado SSL reverso que não foi renovado automaticamente, o que impediu o carregamento das imagens do site, levando-me a assumir que o cache Redis não estava funcionando :man_facepalming:

A construção mostra a notificação, mas o servidor Redis está funcionando corretamente.
Após renovar o certificado SSL, o site voltou a funcionar.

Obrigado pelo seu suporte e desculpe pela minha burrice :sweat_smile:

1 curtida

This topic was automatically closed 30 days after the last reply. New replies are no longer allowed.