79

我正在尝试评估像JackrabbitModeShape这样的内容存储库 ( JSR283 ),但我必须承认,我不明白首先解决了什么问题,即使它是该项目的一个不错的选择。您认为哪些案例是应用的最佳解决方案?与关系数据库不一样吗,除了大小?为什么?指向现实世界示例的额外积分。

提前致谢。

4

1 回答 1

90

JCR 存储库与 RDBMS 不同,因为 JCR 存储库:

  • 是分层的,允许您将内容组织在与您的需求非常匹配的结构中,并且相关信息通常紧密存储在一起,因此易于导航
  • 是灵活的,允许内容适应和发展,使用可以完全“无模式”到完全限制的节点类型系统(例如,像关系数据库)
  • 使用标准的 Java API(例如 javax.jcr)
  • 抽象信息真正存储的位置:许多 JCR 实现可以将内容存储在各种关系数据库和其他存储中,有些可以通过 JCR API 公开非 JCR 存储,有些可以将多个存储联合到一个虚拟存储库中。
  • 支持开箱即用的查询和全文搜索
  • 支持事件、锁定、版本控制和其他功能

您当然可以在自己的应用程序中构建所有或部分这些功能,但这可能与您应用程序的主要目的相去甚远。

哪些应用程序可以从这些功能中受益?内容管理系统使用存储库已有很长时间了,而 JCR(和 Jackrabbit)确实是出于对通用、标准 API 来访问不同内容存储库的需求(请参阅JSR-170JSR-283)。

另一个例子是文档管理系统,它管理电子文件(通常是纸质文档的图像)并提供搜索和查询。DMS 使用存储库已有一段时间了。

工件管理系统可以使用存储库来管理数字工件(通常是文件)以及附加信息(元数据)。JCR 在这里工作得很好,因为您可以将元数据存储在与文件相同的位置:了解这些额外属性的人可以看到它们,不关心的人不必看到它们。我知道Artifactory是一个使用 JCR 的 Maven 存储库实现。还有用于管理 Web 服务工件、数据服务工件和测试工件的存储库。

但是 JCR 存储库不是用于管理文件的。JCR 使用节点层次结构的简单概念,其中节点可以包含命名属性(具有一个或多个值)和子级。允许的属性和子节点完全由节点类型决定,可以根据需要逐个节点地更改和混合。JCR 预定义了一些常用的内置节点类型,例如用于表示存储库中的文件和文件夹的节点类型。您可以重用这些内置类型、扩展它们或编写自己的类型。许多人提倡几乎将 mixin 用作 facet 或 aspect,因此如果一个节点需要承担一个 facet,您可以简单地向该节点添加一个 mixin。

JCR 旨在轻松支持将 XML 内容导入存储库,其中每个元素都映射到一个节点,每个属性都映射到一个属性。很多东西都是用 XML(或 YAML 或 JSON)表示的,所有这些都可以很容易地表示并存储在 JCR 存储库中。例如,考虑一个存储配置信息(通常可能存储在多个 XML 文件中)的 JCR 存储库。JCR 可以版本化该信息,允许从多个进程访问它,启用查询和搜索,并在内容更改时通知应用程序。

JCR 有几个很好的概述,其中包含更多详细信息和示例。其中一些是:

于 2010-10-11T19:39:05.427 回答