All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.aliyun.openservices.log.util.LZ4Encoder Maven / Gradle / Ivy

There is a newer version: 0.6.115
Show newest version
/*
 * Copyright (C) Alibaba Cloud Computing All rights reserved.
 */

package com.aliyun.openservices.log.util;

import com.aliyun.openservices.log.exception.LogException;

import net.jpountz.lz4.LZ4Compressor;
import net.jpountz.lz4.LZ4Exception;
import net.jpountz.lz4.LZ4Factory;
import net.jpountz.lz4.LZ4FastDecompressor;

/**
 * LZ4Encoder is used to compress and decompress the log data
 *
 * @author sls_dev
 */
public class LZ4Encoder {

    public static byte[] compressToLhLz4Chunk(byte[] data) throws LogException {
        final int rawSize = data.length;
        LZ4Factory factory = LZ4Factory.fastestInstance();

        // compress data
        LZ4Compressor compressor = factory.fastCompressor();

        int maxCompressedLength = compressor.maxCompressedLength(rawSize);
        int encodingSize = 0;
        byte[] rawCompressed = new byte[maxCompressedLength];
        try {
            encodingSize = compressor.compress(data, 0, rawSize, rawCompressed, 0, maxCompressedLength);
        } catch (LZ4Exception e) {
            throw new LogException("CompressException", e.getMessage(), "");
        }

        if (encodingSize <= 0) {
            throw new LogException("CompressException", "Invalid encoding size", "");
        }

        byte[] ret = new byte[encodingSize];
        System.arraycopy(rawCompressed, 0, ret, 0, encodingSize);

        return ret;
    }

    public static byte[] decompressFromLhLz4Chunk(byte[] compressedData, int rawSize) throws LogException {

        LZ4Factory factory = LZ4Factory.fastestInstance();

        // decompress data
        LZ4FastDecompressor decompressor = factory.fastDecompressor();

        byte[] restored = new byte[rawSize];
        try {
            decompressor.decompress(compressedData, 0, restored, 0, rawSize);
        } catch (LZ4Exception e) {
            throw new LogException("DecompressException", e.getMessage(), "");
        }
		/*
		for (byte i:restored) {
			if (i == 0) {
				throw new LogException("DecompressException", "Decompressed log data contains \\0, error", "");
			}
		}
		*/

        return restored;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy