Apartment::TenantNotFound (Ошибка при подключении к арендатору 34: FATAL: база данных 34 не существует

Я использую ros-apartment gem для мультитенантности в приложении rails. Я развернул приложение на AWS и иногда получаю следующую ошибку:

Apartment::TenantNotFound (Ошибка при подключении к арендатору 34: FATAL: база данных 34 не существует):

И возврат этой ошибки:

ros-apartment (2.9.0) lib/apartment/adapters/abstract_adapter.rb:268:in `raise_connect_error!'
ros-apartment (2.9.0) lib/apartment/adapters/abstract_adapter.rb:189:in `rescue in connect_to_new'
ros-apartment (2.9.0) lib/apartment/adapters/abstract_adapter.rb:178:in `connect_to_new'
ros-apartment (2.9.0) lib/apartment/adapters/abstract_adapter.rb:76:in `block in switch!'
activesupport (5.2.0) lib/active_support/callbacks.rb:98:in `run_callbacks'
ros-apartment (2.9.0) lib/apartment/adapters/abstract_adapter.rb:75:in `switch!'
ros-apartment (2.9.0) lib/apartment/adapters/abstract_adapter.rb:88:in `switch'
ros-apartment (2.9.0) lib/apartment/elevators/generic.rb:22:in `call'
remotipart (1.4.2) lib/remotipart/middleware.rb:32:in `call'
warden (1.2.9) lib/warden/manager.rb:36:in `block in call'
warden (1.2.9) lib/warden/manager.rb:34:in `catch'
warden (1.2.9) lib/warden/manager.rb:34:in `call'
rack (2.2.3) lib/rack/tempfile_reaper.rb:15:in `call'
rack (2.2.3) lib/rack/etag.rb:27:in `call'
rack (2.2.3) lib/rack/conditional_get.rb:27:in `call'
rack (2.2.3) lib/rack/head.rb:12:in `call'
actionpack (5.2.0) lib/action_dispatch/http/content_security_policy.rb:18:in `call'
rack (2.2.3) lib/rack/session/abstract/id.rb:266:in `context'
rack (2.2.3) lib/rack/session/abstract/id.rb:260:in `call

Также у меня нет базы данных с именем 34, я добавил общие лифты для выбора базы данных из поддомена.

Мой код переключения арендатора в общем коде лифта в apartment.rb выглядит следующим образом:

Rails.application.config.middleware.use Apartment::Elevators::Generic, lambda { |request|
  _host = request.host.split('.').first
  if ExcludedSubdomains.subdomains.include?(_host)
    Rails.configuration.database_configuration[Rails.env]["database"]
  else
    _host
  end
}

Из-за этой проблемы моему серверу требуется слишком много времени для ответа.


person Gaurav Patil    schedule 01.04.2021    source источник
comment
Вы можете исключить 34 из массива ExcludedSubdomains   -  person Patil    schedule 02.04.2021


Ответы (2)


Вы можете добавить свой IP-адрес в массив исключенных субдоменов.

class ExcludedSubdomain
    subdomain = ["xyz", "pqr", "34"]
end

и использовать ExcludedSubdomain.subdomain.include?("34") и предотвратить переключение базы данных.

person Patil    schedule 02.04.2021

Я столкнулся с этой проблемой, потому что IP-адрес моего хоста начинается с 34.xx.xx.xx в соответствии с кодом, который возвращает первый субдомен, он считает, что 34 является первым субдоменом, и из-за этого он ищет базу данных 34 и возникает проблема.

person Gaurav Patil    schedule 02.04.2021