微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

ruby-on-rails – Heroku上的多模式Postgres

我正在扩展现有的Rails应用程序,我必须为它添加多租户支持.我已经做了一些阅读,看看这个应用程序将如何在Heroku上托管,我想我可以利用Postgres的多模式功能.

我已经读过,当使用多个模式时,备份似乎存在一些性能问题.我觉得这些信息有点过时了.有谁知道这是否仍然如此?

此外,还有其他任何性能问题,或者我应该考虑的警告吗?

我已经考虑过为每个表添加一个字段,这样我就可以使用单个模式,并将该字段引用到租户表中,但考虑到时间窗口,多个模式似乎是最佳解决方案.

解决方法

我基于Ryan Bigg和Apartment gem的一些工作,将postgres模式用于多租户网站.

https://leanpub.com/multi-tenancy-rails

https://github.com/influitive/apartment

我发现每个客户端都有一个独立的模式,这是一种优雅的解决方案,可以提供更高程度的数据隔离.我个人觉得性能提高了,因为Postgres可以简单地从表中返回所有结果,而不必过滤到’owner_id’.

我还认为它可以实现更简单的迁移,并允许您在不进行全局更改的情况下调整单个客户数据.例如,您可以向特定客户模式添加列,并使用功能标志来启用自定义功能.

我与性能相关的主要论点是备份是一个周期性的过程,而客户表的范围是每次访问.在此基础上,我会在备份方面遇到任何性能损失,从而降低客户体验.

原文地址:https://www.jb51.cc/ruby/268350.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐