RavenDb:文档刷新功能不会在@refresh标志指定的时间或之后运行
我需要在一段时间后将文档标记为过期,因此我尝试使用 @refresh 功能重新运行订阅并计算我的“过期”标志。我知道有“文档过期”功能,但这个功能会删除我不想要的数据。
我在设置中打开了刷新功能,并在所需文档的元数据中添加了 @refresh UTC 日期时间。例如我手动添加了这个文件:
{
"Name": "My data",
"@metadata": {
"@collection": "Testing",
"@refresh": "2021-04-30T07:41:35.4845961Z"
}
}
看起来我正面临非确定性行为 - 有时会处理刷新有时不会。我尝试了不同的时间组合,并通过代码或 Raven Studio 进行设置。
刷新间隔设置为刷新但仍显示“不到一分钟”
我在用
- 社区许可证(此处未提及文档刷新,但我没有看到任何其他许可证也提及它)
社区许可证扩展 - 尝试了更多版本的 RavenDB,结果相同(5.1.7. 看起来更有希望,因为它工作了一段时间,但一段时间后停止了):
- Windows 10 上Docker 中的4.2.111 服务器/工作室版本
- 5.1.7 服务器/工作室版本
- C# RavenDB.Client 5.1.6
在错误跟踪器中没有找到相关问题
https://issues.hibernaterhinos.com/issues/RavenDB?q=document%20refresh
任何想法要检查什么或可能是什么情况?
编辑:打开登录控制台后,我发现了一些错误日志。看起来像
RavendbProject, Raven.Server.Documents.Expiration.ExpiredDocumentsCleaner, Failed to refresh documents on RavendbProject which are older than 05/17/2021 09:48:47, EXCEPTION: System.NullReferenceException: Object reference not set to an instance of an object.
RavendbProject | at Sparrow.Server.ByteStringContext`1.From(String value, ByteStringType type, ByteString& str) in C:BuildsRavenDB-Stable-5.151024srcSparrow.ServerByteString.cs:line 1297
RavendbProject | at Raven.Server.Documents.DocumentPutAction.PutDocument(DocumentsOperationContext context, String id, String expectedChangeVector, BlittableJsonReaderObject document, Nullable`1 lastModifiedTicks, String changeVector, DocumentFlags flags, NonPersistentDocumentFlags nonPersistentFlags) in C:BuildsRavenDB-Stable-5.151024srcRaven.ServerDocumentsDocumentPutAction.cs:line 190
另外值得一提的是,我的文档存储在 ClusterWide 事务中,因此我可以在其中一个文档中看到相应的标志:
"@flags": "FromClusterTransaction",
我目前的怀疑是,这些文档之一可能会阻止其他文档的刷新。删除集群事务文档后,集合中的其他文档被刷新
THE END
二维码