在Tair中,对于传输的对象做编码和解码的相关转码工作。
目前,Tair支持的转码序列化类型有11种,分别是:
// serialize type
public static final int TAIR_STYPE_INT = 1;
public static final int TAIR_STYPE_STRING = 2;
public static final int TAIR_STYPE_BOOL = 3;
public static final int TAIR_STYPE_LONG = 4;
public static final int TAIR_STYPE_DATE = 5;
public static final int TAIR_STYPE_BYTE = 6;
public static final int TAIR_STYPE_FLOAT = 7;
public static final int TAIR_STYPE_DOUBLE = 8;
public static final int TAIR_STYPE_BYTEARRAY = 9;
public static final int TAIR_STYPE_SERIALIZE = 10;
public static final int TAIR_STYPE_INCDATA = 11;
/**
* (C) 2007-2010 Taobao Inc.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation.
*
*/
package com.taobao.tair.etc;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.util.zip.GZIPInputStream;
import java.util.zip.GZIPOutputStream;
public class TranscoderUtil {
private static final Log log = LogFactory.getLog(TranscoderUtil.class);
public static byte[] encodeLong(long number) {
byte[] rt = new byte[8];
rt[7] = (byte) (number & 0xFF);
rt[6] = (byte) ((number >> 8) & 0xFF);
rt[5] = (byte) ((number >> 16) & 0xFF);
rt[4] = (byte) ((number >> 24) & 0xFF);
rt[3] = (byte) ((number >> 32) & 0xFF);
rt[2] = (byte) ((number >> 40) & 0xFF);
rt[1] = (byte) ((number >> 48) & 0xFF);
rt[0] = (byte) ((number >> 56) & 0xFF);
return rt;
}
public static long decodeLong(byte[] data) {
long rv = 0;
for (byte i : data) {
rv = (rv << 8) | ((i < 0) ? (256 + i)
: i);
}
return rv;
}
public static byte[] encodeInt(int number) {
byte[] fg = new byte[4];
fg[3] = (byte) (number & 0xFF);
fg[2] = (byte) ((number >> 8) & 0xFF);
fg[1] = (byte) ((number >> 16) & 0xFF);
fg[0] = (byte) ((number >> 24) & 0xFF);
return fg;
}
public static int decodeInt(byte[] data) {
assert data.length <= 4 : "Too long to be an int (" + data.length + ") bytes";
return (int) decodeLong(data);
}
public static int getInt(byte[] data, int offset) {
int rv = 0;
rv = ((data[offset+3] < 0) ? (256 + data[offset+3]) : data[offset+3]);
rv = (rv << 8) | ((data[offset+2] < 0) ? (256 + data[offset+2]) : data[offset+2]);
rv = (rv << 8) | ((data[offset+1] < 0) ? (256 + data[offset+1]) : data[offset+1]);
rv = (rv << 8) | ((data[offset] < 0) ? (256 + data[offset]) : data[offset]);
return rv;
}
public static byte[] encodeByte(byte in) {
return new byte[] { in };
}
public static byte decodeByte(byte[] in) {
assert in.length <= 1 : "Too long for a byte";
byte rv = 0;
if (in.length == 1) {
rv = in[0];
}
return rv;
}
public static byte[] encodeBoolean(boolean b) {
byte[] rv = new byte[1];
rv[0] = (byte) (b ? '1'
: '0');
return rv;
}
public static boolean decodeBoolean(byte[] in) {
assert in.length == 1 : "Wrong length for a boolean";
return in[0] == '1';
}
public static byte[] compress(byte[] in) {
if (in == null) {
throw new NullPointerException("Can't compress null");
}
ByteArrayOutputStream bos = new ByteArrayOutputStream();
GZIPOutputStream gz = null;
try {
gz = new GZIPOutputStream(bos);
gz.write(in);
} catch (IOException e) {
throw new RuntimeException("IO exception compressing data", e);
} finally {
try {
gz.close();
bos.close();
} catch (Exception e) {
// should not happen
}
}
byte[] rv = bos.toByteArray();
if (log.isInfoEnabled()) {
log.info("compressed value, size from [" + in.length + "] to [" + rv.length + "]");
}
return rv;
}
public static byte[] decompress(byte[] in) {
ByteArrayOutputStream bos = null;
if (in != null) {
ByteArrayInputStream bis = new ByteArrayInputStream(in);
bos = new ByteArrayOutputStream();
GZIPInputStream gis = null;
try {
gis = new GZIPInputStream(bis);
byte[] buf = new byte[8192];
int r = -1;
while ((r = gis.read(buf)) > 0) {
bos.write(buf, 0, r);
}
} catch (IOException e) {
bos = null;
throw new RuntimeException(e);
} finally {
try {
gis.close();
bos.close();
} catch (Exception e) {
}
}
}
return (bos == null) ? null
: bos.toByteArray();
}
public static byte[] serialize(Object o) {
if (o == null) {
throw new NullPointerException("Can't serialize null");
}
byte[] rv = null;
try {
ByteArrayOutputStream bos = new ByteArrayOutputStream();
ObjectOutputStream os = new ObjectOutputStream(bos);
os.writeObject(o);
os.close();
bos.close();
rv = bos.toByteArray();
} catch (IOException e) {
throw new IllegalArgumentException("Non-serializable object", e);
}
return rv;
}
public static Object deserialize(byte[] in) {
Object rv = null;
try {
if (in != null) {
ByteArrayInputStream bis = new ByteArrayInputStream(in);
ObjectInputStream is = new ObjectInputStream(bis);
rv = is.readObject();
is.close();
bis.close();
}
} catch (Exception e) {
throw new RuntimeException("deserialize failed", e);
}
return rv;
}
public static String decodeString(byte[] data, String charset) {
String rv = null;
try {
if (data != null) {
rv = new String(data, charset);
}
} catch (Exception e) {
throw new RuntimeException(e);
}
return rv;
}
/**
* Encode a string into the current character set.
*/
public static byte[] encodeString(String in, String charset) {
byte[] rv = null;
try {
rv = in.getBytes(charset);
} catch (Exception e) {
throw new RuntimeException(e);
}
return rv;
}
}
分享到:
相关推荐
《深入解析tair源码》 tair,全称为Tencent Advanced In-Memory Storage,是腾讯公司开发的一款高性能、高可用、低延迟的分布式内存存储系统。它主要用于处理大规模数据的快速读写需求,尤其在实时计算、推荐系统、...
Tair与Redis比较 在分布式缓存系统中,Tair和Redis是两个常见的选择。下面,我们将对Tair和Redis进行比较,探讨它们的架构、功能、使用场景和性能特点。 Tair架构 Tair是一个分布式的缓存系统,主要包括四个模块...
Tair 缓存开发指南 Tair 是淘宝网自主开发的 Key/Value 结构数据存储系统,在淘宝网有着大规模的应用。以下是 Tair 的功能和实现细节: 1. Version 支持:Tair 中的每个数据都包含版本号,版本号在每次更新后都会...
《淘宝Tair服务端源码解析》 Tair,全称为Taobao Advanced In-Memory Storage,是淘宝自主研发的一款高性能、高可用的分布式Key/Value存储系统。它在淘宝内部广泛应用于缓存、配置中心、日志存储等多个场景,极大地...
在Tair出现之前的很长一段时间里,像redis、memcache这些知名NoSql数据库是不支持分布式的,在这样的背景下,由淘宝网自主开发并在2010.6开源的一个高性能、高扩展、高可靠分布式缓存,类似map的key/value结构,在...
【分布式缓存tair详解】 Tair是一款由淘宝自主研发的分布式键值存储系统,它主要设计用于处理大量的key-value数据,提供高并发访问和高效的数据存储。Tair分为持久化和非持久化两种模式,非持久化模式下,Tair充当...
通过模块化设计,Tair可以方便地添加新功能或进行定制,例如支持Tair的插件系统可以扩展出如Tair-Graph(图数据库)、Tair-Search(搜索引擎)等子系统。 ### 9. 监控与运维 Tair提供了丰富的监控指标和运维工具,...
**淘宝TAIR使用测试** 淘宝TAIR(Tencent Advanced Internet Repository)是一款由淘宝公司开发的分布式键值存储系统,主要用于处理大规模数据存储和快速访问的需求。TAIR的设计目标是提供高可用性、高性能以及可...
### TAIR集群配置详解 TAIR (TaoBao Advanced In-Memory Database) 是一款由阿里巴巴集团自主研发的高性能、分布式内存存储系统。本文将详细解析TAIR集群的配置步骤及过程中需要注意的关键点。 #### 一、环境准备 ...
tair源码,java,镜像,nosql数据库,阿里巴巴淘宝源码
tair 是淘宝自己开发的一个分布式 key/value 存储引擎. tair 分为持久化和非持久化两种使用方式. 非持久化的 tair 可以看成是一个分布式缓存. 持久化的 tair 将数据存放于磁盘中. 为了解决磁盘损坏导致数据丢失, ...
淘宝tair源代码包,tair 是淘宝自己开发的一个分布式 key/value 存储引擎。
分布式缓存系统Tair是一个专为高性能、高可用性设计的键值存储系统。它支持多种存储引擎,但每个系统实例仅能使用一种。Tair的架构由几个关键组件构成,包括config_server、data_server、storage模块以及一些通用...
阿里云Redis企业版Tair是一款高性能的NoSQL数据库系统,旨在为企业提供更加强大和灵活的数据存储解决方案。Tair最初是阿里巴巴自研的数据库系统,用于应对双11等大型活动的高流量挑战。随着云计算的发展,Tair逐渐...
《memcache、redis、tair性能对比测试报告》详述了在分布缓存技术领域,对这三种主流缓存服务器的性能评估。测试主要目的是在相同功能特性的基础上,对比它们在不同场景下的表现,因此排除了ehcache(组件级缓存)和...
maven 淘宝下的jar包啊
使用阿里中间件RocketMQ、Tair、jstorm对双十一实时交易进行实时计算 使用阿里中间件RocketMQ、Tair、jstorm对双十一实时交易进行实时计算 使用阿里中间件RocketMQ、Tair、jstorm对双十一实时交易进行实时计算 使用...