所以我使用 BooPickle 在将 Scala 类写入 RocksDB 之前对其进行序列化。要序列化一个类,
case class Key(a: Long, b: Int) {
def toStringEncoding: String = s"${a}-${b}"
}
我有这个隐式类
implicit class KeySerializer(key: Key) {
def serialize: Array[Byte] =
Pickle.intoBytes(key.toStringEncoding).array
}
该方法toStringEncoding
是必要的,因为 BooPickle 没有以与 RocksDb 对键排序的要求很好地配合的方式序列化案例类。然后我将一堆键值对写入几个 SST 文件,并将它们摄取到 RocksDb 中。但是,当我从数据库中查找密钥时,找不到它们。
如果我遍历数据库中的所有键,我发现键被成功写入,但是额外的字节被写入数据库中的字节表示。例如,如果key.serialize
输出这样的东西
Array[Byte] = Array( 25, 49, 54, 48, 53, 55, 52, 52, 48, 48, 48, 45, 48, 45, 49, 54, 48, 53, 55, 52, 52, 48, 51, 48, 45, 48, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, ...)
我会在数据库中找到是这样的
Array[Byte] = Array( 25, 49, 54, 48, 53, 55, 52, 52, 48, 48, 48, 45, 48, 45, 49, 54, 48, 53, 55, 52, 52, 48, 51, 48, 45, 48, 51, 101, 52, 97, 49, 100, 102, 48, 50, 53, 5, 8, ...)
额外的非零字节替换字节数组末尾的零字节。另外字节数组的大小也不同。当我调用该serialize
方法时,字节数组的大小为 512,但是当我从数据库中检索密钥时,大小为 4112。有人知道可能是什么原因造成的吗?