如何解决Apartment::TenantNotFound连接到租户 34 时出错:致命:数据库“34”不存在
我在 rails 应用程序中使用 ros-apartment gem
进行多租户。我已在 AWS 上部署了该应用程序,但有时出现以下错误:
Apartment::TenantNotFound(连接到租户 34 时出错:致命:数据库“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
}
因为这个问题,我的服务器需要很长时间来响应。
解决方法
我面临这个问题,因为我的主机 IP 从 34.xx.xx.xx
开始,按照代码它返回第一个子域,它认为 34 是第一个子域,因此它搜索 34 数据库并出现问题
您可以在排除子域数组中添加您的 IP 地址
class ExcludedSubdomain
subdomain = ["xyz","pqr","34"]
end
并使用 ExcludedSubdomain.subdomain.include?("34")
并防止数据库切换。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。