使用 Tinkerpop 中的 g.V() 时,TitanDB 是否将完整图加载到内存中?

Does TitanDB loads full graph into memory when using g.V() from Tinkerpop?

我现在在用 Titan

我想在我的Titan应用中使用"g.V().values()"支持的Tinkerpop,实现图遍历

在我看来,Tinkerpop 在使用此 iterator.Titan 时将全局图加载到内存中似乎是直接调用此方法而不是重写。

那么,Titan 在执行 g.V() 时是否将完整的图形加载到内存中?

如果答案是 true.I,当图形足够大时,您会担心内存大小。

In my view, Tinkerpop loads global graph into memory when using this iterator.

我不确定您是从哪里得出这个结论的,但 TinkerPop 界面的意图恰恰相反。实现 TinkerPop 接口的图形数据库 应该 利用 Iterator 的内存节省功能,并明智地加载数据。我用斜体写 "should" 是因为 TinkerPop 确实没有办法强制执行该要求。当 g.V() 被调用时,没有什么可以阻止图形提供者将其数据库中的所有数据拉入内存。

就是说,我真的不知道有任何持久性(即不在内存中,图形已经驻留在内存中)TinkerPop 实现,包括 Titan。如果是这样的话,泰坦将无法很好地扩展。当然,这并不意味着在具有 g.V() 的 OLTP 样式遍历中对十亿边图中的所有顶点执行全局检索将意味着您会获得良好的结果。如果它完全返回(即超时和其他环境问题),您将等待很长时间才能完成该遍历。对于全局图形查询,在这些情况下,您会希望使用 titan-hadoop 和 OLAP 风格的遍历。