繁体   English   中英

Rails:使用 Apartment 和 MySQL 的多租户

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM