[英]Rails : Multi-tenancy using Apartment and MySQL
我正在使用 Apartment gem & Devise 创建一个应用程序(在 Rails 6.0.1 上),但我不知道如何使用 MySQL 让它工作。
我已经制作了所有配置和内容,生成了我的用户设计模型等,但是当我尝试rails db:migrate
时发生错误:
Migrating tenant
Error while connecting to tenant : Mysql2::Error: No database selected
这意味着我还没有正确配置公寓来使用我的 Mysql 数据库,对吗? 我找不到任何关于如何正确连接它的信息(我可以用初学者的术语理解)。 我的database.yml
有以下内容:
// database.yml
default: &default
adapter: mysql2
encoding: utf8mb4
pool: <%= ENV.fetch("RAILS_MAX_THREADS") { 5 } %>
username: myusername
password: mypassword
socket: /tmp/mysql.sock
(...)
请注意,我的 rails 应用程序中有很好的用户名和密码 :) 一切正常,直到我尝试创建多租户的东西。 这意味着问题可能来自我的config/initializers/apartment.rb
文件?
这是它现在的样子
// config/initializers/apartment.rb
require 'apartment/elevators/subdomain'
Apartment.configure do |config|
config.excluded_models = %w[User]
config.tenant_names = -> { User.pluck :subdomain }
config.use_schemas = true
end
Rails.application.config.middleware.use Apartment::Elevators::Subdomain
编辑:我正在使用公寓的开发分支。 也许这是 Rails 6 的问题?
// Gemfile
gem 'apartment', github: 'influitive/apartment', branch: 'development'
我想现在你已经解决了你的问题,但是对于那些来这里寻找在 Rails 6 中处理多租户的人来说。我自己发现了一些事情:
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.