Обновление пошло не так [устаревший плагин Guest Gate]

Я давно не обновлял свой Discourse, но наконец-то взялся за это. Сначала попробовал через веб-приложение, но возникла ошибка. Затем зашёл на сервер и попытался пересобрать контейнер, но столкнулся с несколькими проблемами нехватки места.

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

Как и было рекомендовано, я запустил discourse-doctor, и вот что, похоже, является основной ошибкой:

2022-10-12 12:12:37.418 UTC [1669] LOG:  база данных была выключена в 2022-10-12 12:09:46 UTC
2022-10-12 12:12:37.452 UTC [1666] LOG:  система базы данных готова принимать подключения
I, [2022-10-12T12:12:42.229967 #1]  INFO -- :
I, [2022-10-12T12:12:42.230254 #1]  INFO -- : > su postgres -c 'createdb discourse' || true
Ошибка: версия PostgreSQL 13 не установлена
I, [2022-10-12T12:12:42.270949 #1]  INFO -- :
I, [2022-10-12T12:12:42.271177 #1]  INFO -- : > su postgres -c 'psql discourse -c "create user discourse;"' || true
psql: подключение к серверу через сокет "/var/run/postgresql/.s.PGSQL.5432" не удалось: такой файл или каталог не существует
        Запущен ли сервер локально и принимает ли он подключения через этот сокет?
I, [2022-10-12T12:12:42.323520 #1]  INFO -- :
I, [2022-10-12T12:12:42.323738 #1]  INFO -- : > su postgres -c 'psql discourse -c "grant all privileges on database discourse to discourse;"' || true
psql: подключение к серверу через сокет "/var/run/postgresql/.s.PGSQL.5432" не удалось: такой файл или каталог не существует
        Запущен ли сервер локально и принимает ли он подключения через этот сокет?
I, [2022-10-12T12:12:42.375939 #1]  INFO -- :
I, [2022-10-12T12:12:42.376152 #1]  INFO -- : > su postgres -c 'psql discourse -c "alter schema public owner to discourse;"'
psql: подключение к серверу через сокет "/var/run/postgresql/.s.PGSQL.5432" не удалось: такой файл или каталог не существует
        Запущен ли сервер локально и принимает ли он подключения через этот сокет?
I, [2022-10-12T12:12:42.429960 #1]  INFO -- :
I, [2022-10-12T12:12:42.430282 #1]  INFO -- : Прерывание асинхронных процессов
I, [2022-10-12T12:12:42.430313 #1]  INFO -- : Отправка INT для HOME=/var/lib/postgresql USER=postgres exec chpst -u postgres:postgres:ssl-cert -U postgres:postgr                                                                                                                                                              es:ssl-cert /usr/lib/postgresql/10/bin/postmaster -D /etc/postgresql/10/main pid: 1666
2022-10-12 12:12:42.430 UTC [1666] LOG:  получен запрос быстрого завершения работы
2022-10-12 12:12:42.445 UTC [1666] LOG:  прерывание всех активных транзакций
2022-10-12 12:12:42.446 UTC [1666] LOG:  рабочий процесс: запуск логической репликации (PID 1675) завершился с кодом выхода 1
2022-10-12 12:12:42.447 UTC [1670] LOG:  завершение работы
2022-10-12 12:12:42.562 UTC [1666] LOG:  система базы данных завершена


ОШИБКА
--------------------
Pups::ExecError: su postgres -c 'psql discourse -c "alter schema public owner to discourse;"' завершилась с ошибкой #<Process::Status: pid 1699 exit 2>
Место возникновения ошибки: /usr/local/lib/ruby/gems/2.7.0/gems/pups-1.1.1/lib/pups/exec_command.rb:117:in `spawn'
Выполнение не удалось с параметрами "su postgres -c 'psql $db_name -c \"alter schema public owner to $db_user;\"'"
Инициализация не удалась с кодом выхода 2
** НЕ УДАЛОСЬ ЗАПУСТИТЬ ИНИЦИАЛИЗАЦИЮ ** Пожалуйста, прокрутите вверх и поищите более ранние сообщения об ошибках; их может быть несколько.
./discourse-doctor может помочь диагностировать проблему.
4f664b8bc922e1b17fb754c66f5f729d1a78d609d10fe228677248e3cace99bb
==================== КОНЕЦ ЖУРНАЛА ПЕРЕСБОРКИ ====================
Не удалось пересобрать приложение.




Есть ли какие-либо советы, как снова всё запустить?

Сколько времени прошло с момента вашего последнего обновления? Вы следовали обновлению PostgreSQL 13?

Вы пробовали пересобирать более одного раза?

Что ж, я каким-то образом запустил всё — похоже, я вручную принудительно использовал старую версию PSQL, но весь мой форум исчез. :rofl: Теперь форум пустой.

Восстанавливаю из резервной копии и надеюсь на лучшее. :man_shrugging:

Вам следует удалить (устаревший) плагин Guest Gate и заменить его на компонент темы.

Хорошо, я запустил восстановление, всё шло нормально, но потом меня разлогинило.

Есть ли способ отследить, завершено ли восстановление? На сайте появляется много ошибок (невозможно войти через SSO), и я не хочу ничего делать, пока процесс не закончится.

В логах я вижу следующую ошибку:

NoMethodError (undefined method `external_id' for #<Topic:0x00007f6463504ac8>
Did you mean?  extend)
(eval):2:in `external_id'
app/serializers/topic_view_serializer.rb:109:in `include_external_id?'
(eval):36:in `_fast_attributes'
app/controllers/application_controller.rb:545:in `render_json_dump'
app/controllers/topics_controller.rb:1204:in `block (2 levels) in perform_show_response'
app/controllers/topics_controller.rb:1194:in `perform_show_response'
app/controllers/topics_controller.rb:169:in `show'
app/controllers/application_controller.rb:413:in `block in with_resolved_locale'
app/controllers/application_controller.rb:413:in `with_resolved_locale'
lib/middleware/omniauth_bypass_middleware.rb:71:in `call'
lib/content_security_policy/middleware.rb:12:in `call'
lib/middleware/anonymous_cache.rb:366:in `call'
config/initializers/100-quiet_logger.rb:23:in `call'
config/initializers/100-silence_logger.rb:31:in `call'
lib/middleware/enforce_hostname.rb:23:in `call'
lib/middleware/request_tracker.rb:202:in `call'
activemodel (7.0.3.1) lib/active_model/attribute_methods.rb:458:in `method_missing'
(eval):2:in `external_id'
app/serializers/topic_view_serializer.rb:109:in `include_external_id?'
active_model_serializers (0.8.4) lib/active_model/serializer.rb:375:in `include?'
(eval):36:in `_fast_attributes'
active_model_serializers (0.8.4) lib/active_model/serializer.rb:468:in `rescue in attributes'
active_model_serializers (0.8.4) lib/active_model/serializer.rb:455:in `attributes'
active_model_serializers (0.8.4) lib/active_model/serializer.rb:480:in `_serializable_hash'
active_model_serializers (0.8.4) lib/active_model/serializer.rb:359:in `serializable_hash'
active_model_serializers (0.8.4) lib/active_model/serializer.rb:347:in `as_json'
activesupport (7.0.3.1) lib/active_support/json/encoding.rb:22:in `encode'
activesupport (7.0.3.1) lib/active_support/json/encoding.rb:22:in `encode'
activesupport (7.0.3.1) lib/active_support/core_ext/object/json.rb:42:in `to_json'
active_model_serializers (0.8.4) lib/active_model/serializer.rb:331:in `to_json'
multi_json (1.15.0) lib/multi_json/adapters/oj.rb:56:in `dump'
multi_json (1.15.0) lib/multi_json/adapters/oj.rb:56:in `dump'
multi_json (1.15.0) lib/multi_json/adapter.rb:25:in `dump'
multi_json (1.15.0) lib/multi_json.rb:139:in `dump'
app/controllers/application_controller.rb:545:in `render_json_dump'
app/controllers/topics_controller.rb:1204:in `block (2 levels) in perform_show_response'
actionpack (7.0.3.1) lib/action_controller/metal/mime_responds.rb:214:in `respond_to'
app/controllers/topics_controller.rb:1194:in `perform_show_response'
app/controllers/topics_controller.rb:169:in `show'
plugins/discourse-category-lockdown/plugin.rb:65:in `show'
actionpack (7.0.3.1) lib/action_controller/metal/basic_implicit_render.rb:6:in `send_action'
actionpack (7.0.3.1) lib/abstract_controller/base.rb:215:in `process_action'
actionpack (7.0.3.1) lib/action_controller/metal/rendering.rb:53:in `process_action'
actionpack (7.0.3.1) lib/abstract_controller/callbacks.rb:234:in `block in process_action'
activesupport (7.0.3.1) lib/active_support/callbacks.rb:118:in `block in run_callbacks'
app/controllers/application_controller.rb:413:in `block in with_resolved_locale'
i18n (1.12.0) lib/i18n.rb:322:in `with_locale'
app/controllers/application_controller.rb:413:in `with_resolved_locale'
activesupport (7.0.3.1) lib/active_support/callbacks.rb:127:in `block in run_callbacks'
activesupport (7.0.3.1) lib/active_support/callbacks.rb:138:in `run_callbacks'
actionpack (7.0.3.1) lib/abstract_controller/callbacks.rb:233:in `process_action'
actionpack (7.0.3.1) lib/action_controller/metal/rescue.rb:22:in `process_action'
actionpack (7.0.3.1) lib/action_controller/metal/instrumentation.rb:67:in `block in process_action'
activesupport (7.0.3.1) lib/active_support/notifications.rb:206:in `block in instrument'
activesupport (7.0.3.1) lib/active_support/notifications/instrumenter.rb:24:in `instrument'
activesupport (7.0.3.1) lib/active_support/notifications.rb:206:in `instrument'
actionpack (7.0.3.1) lib/action_controller/metal/instrumentation.rb:66:in `process_action'
actionpack (7.0.3.1) lib/action_controller/metal/params_wrapper.rb:259:in `process_action'
activerecord (7.0.3.1) lib/active_record/railties/controller_runtime.rb:27:in `process_action'
actionpack (7.0.3.1) lib/abstract_controller/base.rb:151:in `process'
actionview (7.0.3.1) lib/action_view/rendering.rb:39:in `process'
rack-mini-profiler (3.0.0) lib/mini_profiler/profiling_methods.rb:85:in `block in profile_method'
actionpack (7.0.3.1) lib/action_controller/metal.rb:188:in `dispatch'
actionpack (7.0.3.1) lib/action_controller/metal.rb:251:in `dispatch'
actionpack (7.0.3.1) lib/action_dispatch/routing/route_set.rb:49:in `dispatch'
actionpack (7.0.3.1) lib/action_dispatch/routing/route_set.rb:32:in `serve'
actionpack (7.0.3.1) lib/action_dispatch/journey/router.rb:50:in `block in serve'
actionpack (7.0.3.1) lib/action_dispatch/journey/router.rb:32:in `each'
actionpack (7.0.3.1) lib/action_dispatch/journey/router.rb:32:in `serve'
actionpack (7.0.3.1) lib/action_dispatch/routing/route_set.rb:852:in `call'
lib/middleware/omniauth_bypass_middleware.rb:71:in `call'
rack (2.2.4) lib/rack/tempfile_reaper.rb:15:in `call'
rack (2.2.4) lib/rack/conditional_get.rb:27:in `call'
rack (2.2.4) lib/rack/head.rb:12:in `call'
actionpack (7.0.3.1) lib/action_dispatch/http/permissions_policy.rb:38:in `call'
lib/content_security_policy/middleware.rb:12:in `call'
lib/middleware/anonymous_cache.rb:366:in `call'
rack (2.2.4) lib/rack/session/abstract/id.rb:266:in `context'
rack (2.2.4) lib/rack/session/abstract/id.rb:260:in `call'
actionpack (7.0.3.1) lib/action_dispatch/middleware/cookies.rb:697:in `call'
actionpack (7.0.3.1) lib/action_dispatch/middleware/callbacks.rb:27:in `block in call'
activesupport (7.0.3.1) lib/active_support/callbacks.rb:99:in `run_callbacks'
actionpack (7.0.3.1) lib/action_dispatch/middleware/callbacks.rb:26:in `call'
actionpack (7.0.3.1) lib/action_dispatch/middleware/debug_exceptions.rb:28:in `call'
actionpack (7.0.3.1) lib/action_dispatch/middleware/show_exceptions.rb:26:in `call'
logster (2.11.3) lib/logster/middleware/reporter.rb:43:in `call'
railties (7.0.3.1) lib/rails/rack/logger.rb:40:in `call_app'
railties (7.0.3.1) lib/rails/rack/logger.rb:27:in `call'
config/initializers/100-quiet_logger.rb:23:in `call'
config/initializers/100-silence_logger.rb:31:in `call'
actionpack (7.0.3.1) lib/action_dispatch/middleware/remote_ip.rb:93:in `call'
request_store (1.5.1) lib/request_store/middleware.rb:19:in `call'
actionpack (7.0.3.1) lib/action_dispatch/middleware/request_id.rb:26:in `call'
lib/middleware/enforce_hostname.rb:23:in `call'
rack (2.2.4) lib/rack/method_override.rb:24:in `call'
actionpack (7.0.3.1) lib/action_dispatch/middleware/executor.rb:14:in `call'
rack (2.2.4) lib/rack/sendfile.rb:110:in `call'
actionpack (7.0.3.1) lib/action_dispatch/middleware/host_authorization.rb:131:in `call'
rack-mini-profiler (3.0.0) lib/mini_profiler/profiler.rb:249:in `call'
message_bus (4.2.0) lib/message_bus/rack/middleware.rb:60:in `call'
lib/middleware/request_tracker.rb:202:in `call'
railties (7.0.3.1) lib/rails/engine.rb:530:in `call'
railties (7.0.3.1) lib/rails/railtie.rb:226:in `public_send'
railties (7.0.3.1) lib/rails/railtie.rb:226:in `method_missing'
rack (2.2.4) lib/rack/urlmap.rb:74:in `block in call'
rack (2.2.4) lib/rack/urlmap.rb:58:in `each'
rack (2.2.4) lib/rack/urlmap.rb:58:in `call'
unicorn (6.1.0) lib/unicorn/http_server.rb:634:in `process_client'
unicorn (6.1.0) lib/unicorn/http_server.rb:739:in `worker_loop'
unicorn (6.1.0) lib/unicorn/http_server.rb:547:in `spawn_missing_workers'
unicorn (6.1.0) lib/unicorn/http_server.rb:143:in `start'
unicorn (6.1.0) bin/unicorn:128:in `<top (required)>'
vendor/bundle/ruby/2.7.0/bin/unicorn:25:in `load'
vendor/bundle/ruby/2.7.0/bin/unicorn:25:in `<main>'


Ох, отключил Guest Gate, пересобрал ещё раз, и всё снова работает. Спасибо за помощь, ребята.