Erro do Bootstrap com plugin de IA, bundle exec rake db:migrate

Estou enfrentando um erro de bootstrap na versão atual 3.5.0.beta7-dev assim que incluo o plugin de IA em uma configuração de contêiner web_only. A mesma compilação funciona bem sem este plugin.

Pela leitura de Upgrade Error - rake db:migrate index on theme_field_id - #7 by pfaffman, suspeito que a causa raiz seja uma extensão ausente no servidor postgres (externo) 13.20. O servidor possui as extensões hstore, pg_trgm, plpgsql, unaccent e também é usado para uma instalação produtiva do discourse que usa o mesmo código, mas ainda sem o plugin de IA.

Alguém pode identificar as extensões postgres necessárias para o plugin de IA? Não consegui encontrar essa informação no Guia de Auto-hospedagem do Discourse AI. Postagens de bugs semelhantes, como AI Plugin Build Error - 'bundle exec rake db:migrate' failed, usam um cenário diferente e podem não estar relacionadas ao meu caso de uso operacional aqui…

Partes relevantes do web_only.yaml

templates:  
 - "templates/web.template.yml"  
 ## Descomente a linha a seguir para habilitar o listener IPv6  
 #- "templates/web.ipv6.template.yml"  
 - "templates/web.ratelimited.template.yml"  
 - "templates/web.socketed.template.yml"  
 ## Descomente estas duas linhas se desejar adicionar o Lets Encrypt (https)  
 #- "templates/web.ssl.template.yml"  
 #- "templates/web.letsencrypt.ssl.template.yml"

[... ]

## configurar a conectividade com os bancos de dados  
 DISCOURSE_DB_SOCKET: ''  
 DISCOURSE_DB_USERNAME: discourse2  
 DISCOURSE_DB_NAME: discourse2  
 DISCOURSE_DB_PASSWORD: xxx  
 DISCOURSE_DB_HOST: 10.10.10.xx
# cache redis no contêiner vizinho  
 DISCOURSE_REDIS_HOST: redis

[... ]

## 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/discourse/discourse-shared-edits.git  
         - git clone https://github.com/discourse/discourse-chat-integration.git  
         - git clone https://github.com/discourse/discourse-openid-connect.git  
         - git clone https://github.com/discourse/discourse-calendar.git  
         - git clone https://github.com/angusmcleod/discourse-events.git  
         - git clone https://github.com/discourse/discourse-data-explorer.git  
         - git clone https://github.com/discourse/discourse-reactions.git  
         - git clone https://github.com/discourse/discourse-chat.git  
         - git clone https://github.com/discourse/discourse-ai.git  
         - git clone https://github.com/discourse/discourse-topic-voting.git  
         - git clone https://github.com/discourse/discourse-post-voting.git  
         - git clone https://github.com/discourse/discourse-user-notes.git  
         - git clone https://github.com/discourse/discourse-solved.git  
         - git clone https://github.com/discourse/discourse-docs-card-filter.git  
         - git clone https://github.com/discourse/discourse-doc-categories.git  
         - git clone https://github.com/discourse/discourse-assign.git  
         - git clone https://github.com/discourse/discourse-templates.git  
         - git clone https://github.com/discourse/discourse-saved-searches.git  
         - git clone https://github.com/discourse/discourse-tooltips.git  
         - git clone https://github.com/discourse/discourse-category-experts.git  
         - git clone https://github.com/discourse/discourse-activity-pub.git  
         - git clone https://github.com/discourse/discourse-follow.git  
         - git clone https://github.com/nathan-nz/discourse-wikified-posts.git  
         - git clone https://github.com/discourse/discourse-whos-online.git  
         - git clone https://github.com/merefield/discourse-workflow.git
[... ]

## para operação atrás de um balanceador de carga haproxy com nginx local no host do contêiner    
 - replace:  
     filename: /etc/nginx/conf.d/discourse.conf  
     from: "types {"  
     to: |  
       set_real_ip_from 127.0.0.1/24;  
       set_real_ip_from 10.0.0.0/24;  
       real_ip_header X-Forwarded-For;  
       real_ip_recursive on;  
       proxy_set_header Host $http_host;  
       proxy_set_header X-Request-Start “t=${msec}”;  
       proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;  
       proxy_set_header X-Forwarded-Proto https; # $thescheme; substituído  
       proxy_set_header X-Real-IP $remote_addr;  
       types {
[... ]

sudo docker logs -t --tail 1000 web_only

gem install ice_cube -v 0.16.4 -i /var/www/discourse/plugins/discourse-events/gems/3.3.6 --no-document --ignore-dependencies --no-user-install  
Successfully installed ice_cube-0.16.4  
1 gem installed  
gem install icalendar -v 2.8.0 -i /var/www/discourse/plugins/discourse-events/gems/3.3.6 --no-document --ignore-dependencies --no-user-install  
ActiveSupport is required for TimeWithZone support, but not required for general use.  
Successfully installed icalendar-2.8.0  
1 gem installed  
gem install icalendar-recurrence -v 1.1.3 -i /var/www/discourse/plugins/discourse-events/gems/3.3.6 --no-document --ignore-dependencies --no-user-install  
Successfully installed icalendar-recurrence-1.1.3  
1 gem installed  
gem install multipart-post -v 2.4.0 -i /var/www/discourse/plugins/discourse-workflow/gems/3.3.6 --no-document --ignore-dependencies --no-user-install  
Successfully installed multipart-post-2.4.0  
1 gem installed  
gem install faraday-multipart -v 1.0.4 -i /var/www/discourse/plugins/discourse-workflow/gems/3.3.6 --no-document --ignore-dependencies --no-user-install  
Successfully installed faraday-multipart-1.0.4  
1 gem installed  
gem install event_stream_parser -v 1.0.0 -i /var/www/discourse/plugins/discourse-workflow/gems/3.3.6 --no-document --ignore-dependencies --no-user-install  
Successfully installed event_stream_parser-1.0.0  
1 gem installed  
gem install ruby-openai -v 8.1.0 -i /var/www/discourse/plugins/discourse-workflow/gems/3.3.6 --no-document --ignore-dependencies --no-user-install  
Successfully installed ruby-openai-8.1.0  
1 gem installed  
== 20230710171141 EnablePgVectorExtension: migrating ==========================  
-- enable_extension(:vector)  
  
  
  
FAILED  
--------------------  
Pups::ExecError: cd /var/www/discourse && su discourse -c 'bundle exec rake db:migrate' failed with return #<Process::Status: pid 3914 exit 1>  
Location of failure: /usr/local/lib/ruby/gems/3.3.0/gems/pups-1.2.1/lib/pups/exec_command.rb:132:in `spawn'  
exec failed with the params {"cd"=>"$home", "tag"=>"migrate", "hook"=>"db_migrate", "cmd"=>["su discourse -c 'bundle exec rake db:migrate'"]}  
bootstrap failed with exit code 1  
** FAILED TO BOOTSTRAP ** please scroll up and look for earlier error messages, there may be more than one.  
./discourse-doctor may help diagnose the problem.  
3fac1371a3dd8b0d59760e492965c1d7ebb8a09e99549a9483596453f95ce871

Você precisa de GitHub - pgvector/pgvector: Open-source vector similarity search for Postgres

1 curtida

Sim, obrigado, foi isso mesmo, o bootstrap foi bem-sucedido. Talvez essa informação devesse ser adicionada ao guia de auto-hospedagem de IA…

Eu estava pensando que o plugin deveria fazer essa etapa básica durante a migração. Surpreende-me que caiba ao usuário executá-la. Infelizmente, estamos usando o chart bitnami, não tenho muito controle sobre a execução dessa extensão, via chart. Eu odiaria fazer isso manualmente, mas parece que esse é o caminho a seguir.

Gostaria de entender por que o plugin não o adiciona em seu script de migração? Houve algum motivo específico?

No meu caso, a parte do banco de dados do Discourse está localizada em um servidor externo e não faz parte do pacote padrão dos contêineres do Discourse. A extensão de vetor precisa ser instalada com permissões diferentes em comparação com o usuário do banco de dados para o Discourse. Portanto, a instalação teve que ser realizada manualmente, e não como uma etapa do processo de inicialização.

Isso é verdade. Aqui está o que funcionou para mim.

  • Usando o gráfico bitnami discourse
  • Substituir o dockerfile para bitnami postgres e instalar o vector como root
  • Na inicialização do postgres, executou um script init para tornar o usuário discourse o proprietário do vector
  • O restante (incluindo a instalação do plugin) é tratado pelo gráfico bitnami

Aprendi isso da maneira mais difícil. Gostaria que houvesse alguma documentação sobre isso. A documentação do plugin deve mencionar algum pré-requisito.

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