如何解决使用现有检查点文件在 Java 中打开 RocksDB
我有一个流管道,它使用 Rocksdbjni 6.15.2 来管理和检查点状态。我正在尝试在单独的离线 Scala 进程中使用这个相同的库来读取检查点文件,并做一些进一步的处理。
为了测试,我将检查点状态文件夹之一复制到本地文件夹:
ls /mnt/tmp/rocksdb/
010959.sst
CURRENT
MANIFEST-010701
OPTIONS-010704
然后运行这个简单的 Scala 程序:
import org.rocksdb.{Options,RocksDB}
val dbPath = "/mnt/tmp/rocksdb"
val options = new Options().setCreateIfMissing(false)
RocksDB.loadLibrary()
val db: RocksDB = RocksDB.open(options,dbPath)
并遇到此异常:org.rocksdb.RocksDBException: Corruption: IO error: No such file or directoryWhile open a file for random read: /mnt/tmp/rocksdb/010958.ldb: No such file or directory
有没有人遇到过这个异常?为什么 RocksDB 在这里寻找 .ldb
文件?
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。