Discourse Rebuild не работает

При попытке добавить пост с встроенным графиком я получил сообщение об ошибке. Похоже, возникла проблема с защитой файла, и мне было предложено выполнить:

./launcher rebuild app

Я выполнил это и получил следующие ошибки:

FAILED
--------------------
Pups::ExecError: cd /var/www/discourse && su discourse -c 'bundle exec rake themes:update assets:precompile' failed with return #<Process::Status: pid 515 exit 1>
Location of failure: /usr/local/lib/ruby/gems/2.7.0/gems/pups-1.1.1/lib/pups/exec_command.rb:117:in `spawn'
exec failed with the params {"cd"=>"$home", "hook"=>"assets_precompile", "cmd"=>["su discourse -c 'bundle exec rake themes:update assets:precompile'"]}
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.
5c01a6b7b892f68e51e8f275b360af36d7b6f0ac8a3e22c837b0afaaef1705f4

Ошибка немного сбивает с толку. Она появляется примерно через пять минут. Дело в том, что мои данные находятся в /var/discourse, а не в /var/www/discourse. Последняя резервная копия была сделана месяц назад, и я хочу исправить это, не потеряв данные за последний месяц. Есть какие-то идеи? Возможно ли сделать резервную копию базы данных на системе, которая не может быть пересобрана, а затем каким-то образом восстановить её из резервной копии?

Также есть более ранняя ошибка: Preformatted text

warning Skipping preferred cache folder "/home/discourse/.cache/yarn" because it is not writable.
warning Selected the next writable cache folder in the list, will be "/tmp/.yarn-cache-1000".
warning Cannot find a suitable global folder. Tried these: "/usr/local, /home/discourse/.yarn"
node:fs:1336
  handleErrorFromBinding(ctx);
  ^

Error: EACCES: permission denied, mkdir '/home/discourse/.config/configstore'
You don't have access to this file.

    at Object.mkdirSync (node:fs:1336:3)
    at AsyncFunction.module.exports.sync (/var/www/discourse/app/assets/javascripts/node_modules/make-dir/index.js:114:6)
    at Configstore.set all [as all] (/var/www/discourse/app/assets/javascripts/node_modules/configstore/index.js:59:12)
    at Configstore.set (/var/www/discourse/app/assets/javascripts/node_modules/configstore/index.js:91:12)
    at clientId (/var/www/discourse/app/assets/javascripts/node_modules/ember-cli/lib/cli/index.js:55:17)
    at module.exports (/var/www/discourse/app/assets/javascripts/node_modules/ember-cli/lib/cli/index.js:105:13)
    at Object.<anonymous> (/var/www/discourse/app/assets/javascripts/node_modules/ember-cli/bin/ember:34:1)
    at Module._compile (node:internal/modules/cjs/loader:1103:14)
    at Object.Module._extensions..js (node:internal/modules/cjs/loader:1157:10)
    at Module.load (node:internal/modules/cjs/loader:981:32) {
  errno: -13,

Папки /home/discourse вообще не существует.

Эти пути находятся вне контейнера и внутри него.

Есть ли у вас какие-либо плагины, которые могут вызывать эту проблему? Можете ли вы удалить нестандартные плагины и настроить систему так, чтобы это решило проблему?

Джей, я думаю, что разобрался. Мне удалось подключиться к контейнеру, и все пути внутри него каким-то образом были изменены на владельца root. Я вернул их обратно на discourse, и всё снова работает. Проблема в том, что я не уверен, что настройки защиты корректны. Этот экземпляр Discourse работал месяцами без изменений, и вдруг это произошло — я не могу объяснить причину. Есть какие-то идеи?

Кажется, я видел коммит об удалении chown, так что это может быть баг.

Но у вас есть какие-то нестандартные плагины?

Мой Discourse очень стандартный, так что нет. Скорее всего, это произошло после обновления до версии 2.9.0.beta4, которое было несколько дней назад. Я не заметил проблему до сих пор. Beta3 работала нормально. Мне показалось, что, возможно, значительная часть контейнера была изменена на владельца root. Разве большая часть не должна принадлежать пользователю discourse?