使用 nodejs sequelize 的多租户 (SAAS)

Multi tenant (SAAS) using nodejs sequelize

我正在尝试使用 nodejs 和 postgres 构建多租户(/软件即服务),sequelize 作为 ORM。出于安全原因,我决定为每个客户端使用单独的数据库,而不是让所有 table 具有额外列的单个数据库。我实现了结果,但性能并不好,因为我必须根据 sequelize(几乎每个请求)为每个数据库初始化模型。有没有更好的方法来做到这一点?我在续集中遗漏了什么吗?

快速实现我上面的评论。

app.js:

const Sequelize = require('sequelize');

const connections = {
  client1: new Sequelize('postgres://user:pass@example.com:5432/client1'),
  client2: new Sequelize('postgres://user:pass@example.com:5432/client2'),
  client3: new Sequelize('postgres://user:pass@example.com:5432/client3'),
};

const User = require('./models/user');
const Post = require('./models/post');
const Comment = require('./models/comment');

Object.keys(connections).forEach(connection => {
  connection.define('User', userColumns);
  connection.define('Post', postColumns);
  connection.define('Comment', commentColumns);
});

models/user.js:

module.exports = {
  id: {
    type: Sequelize.INTEGER,
    primaryKey: true,
    autoIncrement: true
  },
  username: Sequelize.STRING,
  email: Sequelize.STRING
  // etc, etc
};

显然,无论您使用什么服务器框架,您都需要检测(从 url 我想象的)给定请求使用哪个客户端连接。

或者,考虑编写一个单连接应用程序并部署它的多个实例(我目前正在这样做)。如果您设置在单独的数据库上,可能是一个更简单的选择。

我更喜欢 Postgres 中的模式方法而不是多租户。我在安全方面没有权威,但它应该比基于 table 的多租户更好。灾难恢复也应该比基于 table 的 MT 稍微容易一些,但仍然比使用单独的数据库差。

我设法使用 ES6 代理在 Sequilize 中实现了这一点。这对您的 Node 版本提出了严格的要求,但如果您愿意至少使用 v6.9.2,您可以试试我的库:

https://www.npmjs.com/package/sequelize-multi-tenant-enhancer