- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我正在研究一种使用 node.js + mongoose 和 mongodb 实现多数据库以支持 Multi-Tenancy 的好方法。
我发现 mongoose 支持一种名为 createConnection()
的方法,我想知道使用它的最佳实践。实际上我将所有这些连接存储在一个数组中,由租户分隔。就像:
var connections = [
{ tenant: 'TenantA', connection: mongoose.createConnection('tenant-a') },
{ tenant: 'TenantB', connection: mongoose.createConnection('tenant-b') }
];
假设用户发送他将通过请求 header 登录的租户,我在 express 的一个非常早期的中间件中得到它。
app.use(function (req, res, next) {
req.mongoConnection = connections.find({tenant: req.get('tenant')});
});
问题是,静态存储这些连接是否可以,或者更好的做法是在每次发出请求时创建该连接?
编辑 2014-09-09 - 有关软件要求的更多信息
起初我们将有大约 3 个租户,但我们的计划是在一两年内将这个数字增加到 40 个。读操作比写操作多,它基本上是一个带有机器学习的大数据系统。它不是免费增值软件。由于历史数据的数量,数据库非常大,但是将非常旧的数据移动到另一个位置不是问题(我们已经考虑过了)。如果我们的数据库机器上的可用资源用完了,我们计划稍后对其进行分片,我们也可以将不同机器上的一些租户分开。
最让我感兴趣的是,有些人说为 Multi-Tenancy 设置前缀集合不是一个好主意,但原因很简单。
https://docs.compose.io/use-cases/multi-tenant.html
http://themongodba.wordpress.com/2014/04/20/building-fast-scalable-multi-tenant-apps-with-mongodb/
最佳答案
我不建议手动创建和管理这些单独的连接。我不知道您的 Multi-Tenancy 要求的详细信息(租户数量、数据库大小、预期交易数量等),但我认为使用类似 Mongoose's useDb function 的东西会更好。 .然后 Mongoose 可以处理所有的连接池细节。
我要探索的第一个方向是在单独的 Node 进程上设置每个租户。在单独的 Node 进程中运行租户有一些有趣的好处。从安全角度(隔离内存)和稳定性角度(一个租户进程崩溃不会影响其他租户进程)来看,这是有意义的。
假设您基于 URL 租赁,您将在实际租户服务器前设置一个代理服务器。它的工作是查看 URL 并根据该信息路由到正确的进程。这是一个非常简单的 node http proxy设置。每个租户实例可以是完全相同的代码库,但使用不同的配置启动(它告诉他们使用什么 mongo 连接字符串)。
这意味着您可以设计您的实际应用程序,就像它不是 Multi-Tenancy 一样。每个进程只知道一个mongo数据库,不需要 Multi-Tenancy 逻辑。它还使您能够在以后根据负载轻松拆分流量。如果您出于性能原因需要拆分租户,您可以在代理级别透明地进行。 DNS 都可以保持不变,您只需将实例所在的服务器移到幕后即可。您甚至可以让代理平衡多个服务器之间对租户的请求。
关于node.js - Mongoose 在 node.js 中为 Multi-Tenancy 支持创建连接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25551732/
当我保存4条记录时,我需要将它们一一保存,所以我的代码是 a.save(function(){ b.save(function(){ c.save(function(){ d.save(f
Mongoose在版本4.2.7中创建了一个新的单个子文档功能(documentation和feature request),允许使用单个嵌入式子文档架构,其行为方式与一对多子文档的行为相同。 在父级
Mongoose 版本 >= 4.0 有一个时间戳选项,当 timestamps 设置为 时,该选项会为架构创建 updatedAt 和 createdAt 字段正确。 http://mongoose
我注意到某些图书馆喜欢 mock 鹅 ( https://github.com/mccormicka/Mockgoose/blob/master/test/index.spec.js ) 使用 req
我正在与 Mongoose 合作。我见过很多开发者发出以下命令: mongoose.Promise = global.Promise; 然后我很好奇 mongoose.Promise 的原始值是什么。
当我运行与数据库大量连接和断开连接的测试时,我收到以下警告。 (node) warning: possible EventEmitter memory leak detected. 11 connec
我可以在 Mongoose 的子文档数组中填充动态引用(使用“refPath”)虚拟字段吗? 数据结构如下 Group - Members -> User 代码:模型/模式 let MemberSc
我正在我的应用程序中做一些测试,看看内存缓存是否真的在工作。但是,由于 memory-cache 显然没有公开“命中”事件,我无法判断是否真的从缓存中获取数据。所以我试着看看当应用程序实际从数据库中获
我是 nestjs 的新手。我使用 @nestjs/mongoose,我需要在我的类模式中引用嵌套对象中的几个字段,但我不知道该怎么做。 dietDays 对象必须包含一个日期字段和包含对 Meal
我是 mongodb 的新手,我有一个这样的数据模型 { last_updated: Date.now(), csgo_items:[ {name: 'name', p
这是我的方案: var documentSchema = mongoose.Schema({ 'facts': [{ 'type': { type: String, requi
我想删除多个 _ids = ['123', '234', '345']; _ids.forEach(_id => { await model.deleteOne({ _id }); }); 有没有
我有一个像这样的 Mongoose 模式: var Address = { doorNo:String, city:String, state:String, coun
我的文档包含一个名为 clients 的字段那应该包含一组客户端ID。 { "first_name":"Nick", "last_name":"Parsons", "email":"nic
我遇到了以下我无法理解的代码行,尽管有很多教程提供了与 populate 的示例相关的信息。但没有一个能解释它究竟意味着什么。这是一个例子 var mongoose = require('mongoo
我有一个具有多个唯一性的架构,如下所示: var userSchema = new mongoose.Schema({ user: { type: String, unique:
我有一个 Mongoose 模式,其中有 4 个子模式。我一直在关注这里的文档https://github.com/LearnBoost/mongoose关于嵌入文档 var scenarios =
我希望每个字符串属性都默认设置为 true。有办法吗? ?? mongoose.Schema.String -> default { trim: true } var schema = new Sch
我有这个代码 var ClientSchema = new Schema({ name: {type: String, required: true, trim: true} }); var Cl
许多教程告诉您在您的 userSchema 页面中使用 bycrypt。保存新用户后,它会附带加密密码。伟大的。然而,我想,当我用某些东西编辑用户时,它也会重新哈希密码,导致无法登录。你能给我一个解决
我是一名优秀的程序员,十分优秀!