Current_hostname: неопределенная константа

Привет! У нас здесь довольно сложная настройка, так как нам нужно использовать k8s для хостинга нашего форума, но я постараюсь объяснить всё максимально просто.

При использовании этого файла application.yml во время запуска возникает следующая ошибка. Это произошло впервые с прошлой ночи — до этого всё работало отлично, но после повторного развёртывания система внезапно перестала работать.

Не обращайте внимания на изменения переменных окружения для электронной почты в этом YAML-файле — мы отлаживали что-то другое.

=> Запуск Puma
=> Приложение Rails 7.0.2.4 запускается в режиме production
=> Выполните `bin/rails server --help` для получения дополнительных опций запуска
Выход
/var/www/discourse/lib/discourse.rb:443:in `current_hostname': неопределённая константа Discourse::SiteSetting (NameError)
Возможно, вы имели в виду: Discourse::SiteSettingMissing
        из /var/www/discourse/config/initializers/100-verify_config.rb:7:in `<main>'
        из /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/bootsnap-1.11.1/lib/bootsnap/load_path_cache/core_ext/kernel_require.rb:39:in `load'
        из /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/bootsnap-1.11.1/lib/bootsnap/load_path_cache/core_ext/kernel_require.rb:39:in `load'
        из /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/railties-7.0.2.4/lib/rails/engine.rb:667:in `block in load_config_initializer'
        из /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/activesupport-7.0.2.4/lib/active_support/notifications.rb:208:in `instrument'
        из /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/railties-7.0.2.4/lib/rails/engine.rb:666:in `load_config_initializer'
        из /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/railties-7.0.2.4/lib/rails/engine.rb:620:in `block (2 levels) in <class:Engine>'
        из /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/railties-7.0.2.4/lib/rails/engine.rb:619:in `each'
        из /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/railties-7.0.2.4/lib/rails/engine.rb:619:in `block in <class:Engine>'
        из /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/railties-7.0.2.4/lib/rails/initializable.rb:32:in `instance_exec'
        из /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/railties-7.0.2.4/lib/rails/initializable.rb:32:in `run'
        из /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/railties-7.0.2.4/lib/rails/initializable.rb:61:in `block in run_initializers'
        из /usr/local/lib/ruby/2.7.0/tsort.rb:228:in `block in tsort_each'
        из /usr/local/lib/ruby/2.7.0/tsort.rb:350:in `block (2 levels) in each_strongly_connected_component'
        из /usr/local/lib/ruby/2.7.0/tsort.rb:422:in `block (2 levels) in each_strongly_connected_component_from'
        из /usr/local/lib/ruby/2.7.0/tsort.rb:431:in `each_strongly_connected_component_from'
        из /usr/local/lib/ruby/2.7.0/tsort.rb:421:in `block in each_strongly_connected_component_from'
        из /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/railties-7.0.2.4/lib/rails/initializable.rb:50:in `each'
        из /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/railties-7.0.2.4/lib/rails/initializable.rb:50:in `tsort_each_child'
        из /usr/local/lib/ruby/2.7.0/tsort.rb:415:in `call'
        из /usr/local/lib/ruby/2.7.0/tsort.rb:415:in `each_strongly_connected_component_from'
        из /usr/local/lib/ruby/2.7.0/tsort.rb:349:in `block in each_strongly_connected_component'
        из /usr/local/lib/ruby/2.7.0/tsort.rb:347:in `each'
        из /usr/local/lib/ruby/2.7.0/tsort.rb:347:in `call'
        из /usr/local/lib/ruby/2.7.0/tsort.rb:347:in `each_strongly_connected_component'
        из /usr/local/lib/ruby/2.7.0/tsort.rb:226:in `tsort_each'
        из /usr/local/lib/ruby/2.7.0/tsort.rb:205:in `tsort_each'
        из /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/railties-7.0.2.4/lib/rails/initializable.rb:60:in `run_initializers'
        из /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/railties-7.0.2.4/lib/rails/application.rb:372:in `initialize!'
        из /var/www/discourse/config/environment.rb:7:in `<main>'
        из /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/bootsnap-1.11.1/lib/bootsnap/load_path_cache/core_ext/kernel_require.rb:30:in `require'
        из /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/bootsnap-1.11.1/lib/bootsnap/load_path_cache/core_ext/kernel_require.rb:30:in `require'
        из /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/zeitwerk-2.5.4/lib/zeitwerk/kernel.rb:35:in `require'
        из config.ru:6:in `block in <main>'
        из /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/rack-2.2.3/lib/rack/builder.rb:116:in `eval'
        из /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/rack-2.2.3/lib/rack/builder.rb:116:in `new_from_string'
        из /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/rack-2.2.3/lib/rack/builder.rb:105:in `load_file'
        из /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/rack-2.2.3/lib/rack/builder.rb:66:in `parse_file'
        из /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/rack-2.2.3/lib/rack/server.rb:349:in `build_app_and_options_from_config'
        из /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/rack-2.2.3/lib/rack/server.rb:249:in `app'
        из /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/rack-2.2.3/lib/rack/server.rb:422:in `wrapped_app'
        из /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/rack-2.2.3/lib/rack/server.rb:312:in `block in start'
        из /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/rack-2.2.3/lib/rack/server.rb:379:in `handle_profiling'
        из /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/rack-2.2.3/lib/rack/server.rb:311:in `start'
        из /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/railties-7.0.2.4/lib/rails/commands/server/server_command.rb:38:in `start'
        из /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/railties-7.0.2.4/lib/rails/commands/server/server_command.rb:143:in `block in perform'
        из /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/railties-7.0.2.4/lib/rails/commands/server/server_command.rb:134:in `tap'
        из /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/railties-7.0.2.4/lib/rails/commands/server/server_command.rb:134:in `perform'
        из /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/thor-1.2.1/lib/thor/command.rb:27:in `run'
        из /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/thor-1.2.1/lib/thor/invocation.rb:127:in `invoke_command'
        из /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/thor-1.2.1/lib/thor.rb:392:in `dispatch'
        из /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/railties-7.0.2.4/lib/rails/command/base.rb:87:in `perform'
        из /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/railties-7.0.2.4/lib/rails/command.rb:48:in `invoke'
        из /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/railties-7.0.2.4/lib/rails/commands.rb:18:in `<main>'
        из /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/bootsnap-1.11.1/lib/bootsnap/load_path_cache/core_ext/kernel_require.rb:30:in `require'
        из /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/bootsnap-1.11.1/lib/bootsnap/load_path_cache/core_ext/kernel_require.rb:30:in `require'
        из bin/rails:18:in `<main>'

Мы быстро просмотрели исходный код (хотя большинство из нас не знакомы с Ruby), но пока не можем понять, в чём проблема. Есть какие-то идеи?

Используйте лаунчер для сборки образа и запуска его с переменными окружения, необходимыми для его работы. Их можно получить с помощью команды лаунчера, которая показывает только вызов запуска (посмотрите код лаунчера, чтобы узнать, как это сделать).

Вы можете либо собрать его с рабочей базой данных, а затем запустить, либо собрать его с временной базой данных, а затем выполнить миграцию и предварительную компиляцию ресурсов после запуска.

Всё это выходит за рамки поддержки, доступной здесь.

Или вы можете использовать Bitnami (тоже не поддерживается здесь).

Спасибо за ответ, я очень это ценю, особенно учитывая, что k8s здесь немного выходит за рамки.

Мы не можем использовать Bitnami напрямую, так как нам нужно добавить плагины к экземпляру, но в целом это кажется полезной рекомендацией.

Мы ещё раз перепроверяем всё, спасибо за подсказку насчёт лаунчера — надеюсь, мы что-то найдём.

Это действительно оказалось проблемой, связанной с отсутствием переменных окружения — не в файлах сборки, а на стороне k8s. Спасибо за помощь.