asp.net MVC中RavenDB中的多租户索引

时间:2012-01-06 08:21:05

标签: asp.net-mvc ravendb

在多租户RavenDB应用程序(每个租户一个数据库,以及一个具有一般租户数据的'概述'数据库)中,索引创建策略是什么? (asp.net mvc)

在简单(非多租户)应用程序中,您可以在global.asax中创建索引。

  • 从理论上讲,您可以查询每个租户,并在global.asax中为每个租户创建索引。但是,当租户数量上升时,我猜这将是一个巨大的表现......
  • 创建租户创建索引是不可能的,因为现有租户应该能够获得更新的新索引。

那么关于如何以及何时创建这些索引的最佳实践是什么?

1 个答案:

答案 0 :(得分:10)

您可以在应用程序启动时使用此方法,无需担心perf。

public static void CreateIndexesForDatabases(Assembly assemblyToScanForIndexingTasks, IDocumentStore documentStore, string[] databases)
{
    var catalog = new CompositionContainer(new AssemblyCatalog(assemblyToScanForIndexingTasks));
    foreach (var database in databases)
    {
        IndexCreation.CreateIndexes(catalog, documentStore.DatabaseCommands.ForDatabase(database), documentStore.Conventions);
    }
}

不要忘记包含Raven.Client.Extensions