Ai
1 Star 1 Fork 1

一叶浮尘/kafka-streams-examples

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
TopCMSSerde.scala 2.34 KB
一键复制 编辑 原始数据 按行查看 历史
Matthias J. Sax 提交于 2017-09-08 09:33 +08:00 . Fix license headers
/*
* Copyright Confluent Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package io.confluent.examples.streams.algebird
import java.util
import com.twitter.algebird.TopCMS
import com.twitter.chill.ScalaKryoInstantiator
import org.apache.kafka.common.errors.SerializationException
import org.apache.kafka.common.serialization._
class TopCMSSerializer[T] extends Serializer[TopCMS[T]] {
override def configure(configs: util.Map[String, _], isKey: Boolean): Unit = {
// nothing to do
}
override def serialize(topic: String, cms: TopCMS[T]): Array[Byte] =
if (cms == null) null
else ScalaKryoInstantiator.defaultPool.toBytesWithClass(cms)
override def close(): Unit = {
// nothing to do
}
}
class TopCMSDeserializer[T] extends Deserializer[TopCMS[T]] {
override def configure(configs: util.Map[String, _], isKey: Boolean): Unit = {
// nothing to do
}
override def deserialize(topic: String, bytes: Array[Byte]): TopCMS[T] =
if (bytes == null) null
else if (bytes.isEmpty) throw new SerializationException("byte array must not be empty")
else ScalaKryoInstantiator.defaultPool.fromBytes(bytes).asInstanceOf[TopCMS[T]]
override def close(): Unit = {
// nothing to do
}
}
/**
* A [[Serde]] for [[TopCMS]].
*
* =Usage=
*
* {{{
* val anyTopic = "any-topic"
* val cms: TopCMS[String] = ???
* val serde: Serde[TopCMS[String]] = TopCMSSerde[String]
*
* val bytes: Array[Byte] = serde.serializer().serialize(anyTopic, cms)
* val restoredCms: TopCMS[String] = serde.deserializer().deserialize(anyTopic, bytes)
* }}}
*
* =Future Work=
*
* We could perhaps be more efficient if we serialized not the full [[TopCMS]] instance but only
* its relevant fields.
*/
object TopCMSSerde {
def apply[T]: Serde[TopCMS[T]] = Serdes.serdeFrom(new TopCMSSerializer[T], new TopCMSDeserializer[T])
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Java
1
https://gitee.com/thomas9696/kafka-streams-examples.git
git@gitee.com:thomas9696/kafka-streams-examples.git
thomas9696
kafka-streams-examples
kafka-streams-examples
master

搜索帮助